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PREFACE 



This publication provides user information about the IMP-16 Debugging Program (DEBUG), the Loader 
Programs, Teletype Input/Output Routines, Firmware (PROM, ROM) Paper Tape Generation, and the 
IMP-16 Source File Editor. Supplemental information is included in the appendixes. Familiarity with 
the IMP-16 Programming and Assembler Manual is a prerequisite for using and understanding the infor- 
mation described in this manual. 

This manual was previously titled, "IMP-16L Utilities Reference Manual, Publications Number 4200025A". 
Henceforth, it shall be titled, "IMP-16 Utilities Reference Manual, Order No. IMP-16S/025YB and 
Publications Number 4200025B". 

Copies of this publication and other National Semiconductor publications may be obtained from the sales 
offices listed on the back cover. The information in this publication is subject to change without notice. 
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Chapter 1 



DEBUG 



1. 1 INTRODUCTION 

DEBUG is a relocatable object program that supervises the operation of a user's program during checkout, 
DEBUG provides the following facilities for testing computer programs. 

• Printing selected areas of memory in hexadecimal or ASCII format, 

• Modifying the contents of selected areas in memory. 

• Modifying computer registers including the stack, 

• Inserting instruction breakpoint halts. 

• Taking memory snapshots during execution of user's program. 

• Initiating execution at any point in program, 

• Searching memory. 



1.2 USAGE 

DEBUG is a relocatable load module that is loaded into the user's environment as any other relocatable 

program. DEBUG is initially entered through the global location DEBUG. This may be performed by the loader 
at the completion of the loading of all programs, by a direct jump from a user's program or by an alteration 
to the program counter at the control panel. DEBUG may also be entered through the global location, DEBUGl. 
This entry point loads locations 0 and 3 with an initialization routine that enables the user to recover to 
DEBUG by pressii^ the INITIALIZE button and then the RUN button. 

DEBUG is self-contained; it includes all of its own input and output. The output and formatting ability of 
DEBUG is available to the user by subroutine calls to the global UCALL program in DEBUG. The calling 
sequence is as follows: 

JSR UCALL 

. WORD xxxxxxxx ;BASE LOCATION TO PRINT 

. WORD xxxxxxxx ;TOP LOCATION TO PRINT 

NOTE 

The definitions of the above assembler language instructions are given in the 
IMP-16 Programming and Assembler Manual. The locations specified are 
formatted with eight words per output line and are displayed on the Teletype. 
The use of UCALL is an independent subfunction of DEBUG and does not affect 
normal DEBUG control. 

1.2.1 Memory Requirements 

The following memory is needed to run DEBUG: 

Top Sector: X'42D or 1069jo words. 

Base Page: 6 words. 
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1.3 DEBUG LANGUAGE 



The control statements which are used to command the operation of DEBUG are confined within a set of 
rules which define the syntax (the format of control statements) and semantics (the meanings of the various 
symbols and characters comprising the control statement) of the language. 

1, 3, 1 Conventions Used In This Chapter 

The following notation conventions are used to describe the commands, both in the general case (in the 
command descriptions) and in the specific case (in the examples). 

• Mixed upper- and lower-case characters are used for comments and notes. 

• Nonunderlined characters, numbers, and symbols, used in the examples, indicate computer- 
generated output from the Teletype printer. 

For example: TURN ON PUNCH 

• Underlined characters, numbers, and symbols, used in the examples, indicate user- 
generated input at the Teletype keyboard. Two types of underlined statements are 
used: 

1) Lower-case statements or statement parts represent the general case 
(to be further defined by the rules of syntax), 

2) Upper-case statements or statement parts represent l^e exact (specific) 
form of the input required to be typed in. 

For example: - T <address argument^ (general case) 

- T 2345;7F (specific case) 

- NOTE ADDRESS (specific case) 

• Circled, iqiper-case characters represent operation of Teletyi)e keyboard keys that do 
not generate a printed character. 

For example: (CR) represents the carriage return key. 



(alt mode) represents the alternate mode key. 

• (cTRL/x ) represents the operation of the CONTROL key in conjimction with an alphabetic 
key. The CONTROL key must be depressed first, prior to pressing the alphabetic key, and 
held in while the alphabetic key is pressed. The combined symbol is circled because a control 
operation is initiated; no printed symbol is produced. 



1, 3, 2 Syntax and Semantics 

The basic elements of DEBUG commands are defined below. In the formal (symbolic) descriptions of 

DEBUG commands, the following symbols are used: 

<a> Specifies an element "a" either of a command or of another element. 

::= May be read as, is defined as, and appears in a statement which defines the 

element to its left. 
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a I b I c Indicates that at least one of the elements (a, b, c, etc.) should be specified in 
tiie command (a or b or c or . . , etc.). 

j a ( Indicates that one of the elements specified inside the braces must be included in the 

statement, 

[a] Indicates that the element(s) specified within the brackets are optional and need not be 

included in the command, unless desired. 



1. 3. 3 Syntax 



The following meanings are assigned to the terms used in the general-case form of the statements. 



<hexadecunal number) :; 
<address argument) ::= 

<memory address) ::= 
<memory address range) 



<C register address) ::= 



^register address range) ::= 



<camment) ::= 



From one to four digits from the hexadecimal set 
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F. 
Leading zeros may be omitted. 



Memory address 
Memory address range 
Register address 
Register address range 



A four-digit hexadecimal number specifying a memory 
location, 

A memory address, fdlowed with a colon (:), followed 
with a second memory address. 

For example: 3528:354A 

The memory address to the left of the colon represents 
the lower limit of the range; the memory address to 
the right of the colon represents the high limit of the 
range. 

The letter 'R», followed with a two-digit hexadecimal 
number from the range of 0 through X'lS. Because 
leading zeros may be omitted, the number may appear 
as a one-, or two-digit nimiber. 

For example: RO, R13, R5 

The letter 'R» alone, specifying all registers; or 
a register address, followed with a colon (:), foUowed 
with a two-digit hexadecimal number. The register 
address to the left of the colon represents the lower 
limit of the range; the hexadecimal nxmber to the 
right of the colon represents the upper limit of the 
range. The upper limit must be numerically greater 
than the lower limit. 

For example: R6:13 

English language text, including letters and numbers, 
exactly as fyped in. 
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<value> ::= A four-digit hexadecimal number used as the contents 

of a memory location or the contents of a register. 
Consists of a 16-bit number. May also be specified 
as two ASCII characters. 

For example: 124A, 2235, 0060, 'GO' 

ASCn characters ::= A two-character set of ASCII characters, preceded 

with and termihated by a single quote. 

For example: 'AX' 



1, 3, 4 Semantics 

All numbers ii?)ut to DEBUG are interpreted as hexadecimal digits. Characters may be either decoded as 
ASCn or hexadecimal, depending on the particular context. The following description explains the use of 

Delimiter of address and range arguments. 

Delimiter for a range argument; signifies that all the 
locations from the first entry througih the last are 
included in the range. For example, a:b signifies 
all the locations from a through b, including a and b. 

Signifies that the address foUowii^ the character R 
is a register address or register address range, A 
two-digit hexadecimal number is associated with the 
range symbol; this number is limited to the range 0 
throi^h X»13. 

The values 0 throi^ 3 are for registers ACO, ACl, 
AC2, and ACS. The values 4 through X'13 are for the 
stack contents, 

R without any value represents all registers, 0 
through X»13, 

The current location (CL) is the last location 
addressed by the previous DEBUG command. 



1.4 C OMMUNIC ATIONS 

The user can communicate with DEBUG through a Teletype keyboard, printer, paper tape punch, and paper 
tape reader. Whenever DEBUG takes control, it types the minus sign character (-) to indicate that it is 
ready to accept a command. The user then may type contod statements to direct the operation of DEBUG. 

All command s must be terminated by a carriage return @ Jjr a line feed ^ . To ignore a command, 
(alt mode) key may be pressed at any time before the ^ or the (CR) ; in this case, the # symbol 
is printed and no action occurs. If DEBUG detects an error inthe commana; it types a question mark (?) 
and prompts for a new command. 

As information is transmitted to the Teletype, the Teletype is interrogated for input. If any character is 
detected, the current output is terminated and the user is prompted for another DEBUG command. This 
feature is particidarly useful for terminatii^ excessive or undesirable output. 



certain characters: 
, (comma) 
: (colon) 

R 



(period) 
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More specific information pertaining to particular commands and situations is given in the appropriate 
command descriptions, below. 



Control is returned to DEBUG from a user's program by use of the HALT command. Upon halting, DEBUG 
types the halt address. Control is transferred back to the user's program from DEBUG by the GO directive. 
Details pertaining to the HALT and GO directives are described under the descriptions of the commands 
Ihem selves. 



1,5 DEBUG COMMANDS 

DEBUG commands consist of a single alphabetic character representing the command to be performed, followed 
by a list of the arguments for the commanded operation. The arguments are separated by commas. The 
numeric fields in an argument list must be in hexadecimal notation; leading zeros may be omitted. Blank 
characters are ignored, except when enclosed by quotation marks. In this manner, blanks may be used to 
enhance readability. A statement must be terminated by a carriage return or a line feed. 



1, 5, 1 Command Descriptions 

The commands that are used in DEBUG are described in the fdlowing paragraphs. In the examples contained 
within the command descriptions, all information input by the user is underlined to distinguish it from the 
information generated by DEBUG. This is fiilly discussed in paragraph 1, 3. 1. 



1.5.2 TYPE 



The contents of the specified locations are printed on the terminal in hexadecimal notation. The starting 
address is printed, followed by one to ei^t locations per line. If the contents of consecutive locations 
(starting at any location on a line and extendii^ to the end of the line) are alike, only the first of the like 
locations is printed. The remaining ones are omitted. The next line also is omitted if the contents of 
all locations on the line are identical to the contents of the last printed location on the previous line. However, 
if the contents of any location within such a line are different, then the contents of the locations for that line 
are printed according to the rules given above. The address for a new line always is a multiple of 8 for 
consistency and ease of reading. The final location referenced becomes the value of the current location. 
The format for the TYPE printout is illustrated below. 

A printout of the contents of locations 104 through 120 is requested as follows: 



-T <address argument) [ , <address argument) 



• O O • • 0 



] 




DEBUG responds with the following output: 



(typical data) 



0104 
OlOC 
0114 

one 



88DF 
OOFF 

08FF 
OOFB 



08DF 
88FF 

08FF 
OOFB 



08DF 
08FF 

88FF 
A8FB 



08FF 
88DF 

08FB 
88F3 



OOFF 
88FF 

88FB 
4000 



80FF 
805F 
80EB 



08FF 88FF 
88DF 08DF 
80FB 



(Would have been 80 FB) 
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CHAR 



-C <address argument) [ , <address argument) 



] 
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This command performs in a manner similar to that of the TYPE command with the exception that the infor- 
mation is printed in ASCH character format. The output line consists of the contents of one to eight words 
preceded by the address of the first word. The format for the CHAR printout is illustrated below. 

The following example shows the memory contents in locations 220 through 223, interpreted as hexadecimal 
(TYPE statement) and ASCII (CHAR statement). 

Using the TYPE statement, 

-T 220:223 (cr) 



0220 4131 4242 4147 4243 

Using the CHAR statement, 
-C 220:223 (cr) 



0220 Al BB AG BC 
An ASCn to hexadecimal conversion table is included in appendix A. 
1,5.4 ALTER 

^kmemory address) I <hexadecimal number) [,<...), ...] 
I <register address) I l j 

The ALTER command alters the contents of the specified memory or register location(s). Arithmetic and 
stack registers have register addresses 0 through 3 and 4 through X'lS, respectively. Address 4 is the 
top of the stack; that is, the last value placed in the stack. The user specifies the address of the location 
or register that is to be altered^dlowed by a comma and the value to be placed in the addressed l^ation. 
If the value is terminated by (CR) , the value is stored and the ALTER is terminated. If an ^F) 
terminates the expression, the value is stored and the user is prompted with the address of the next location 
or register. A comma may be used to indicate successive locations or registers to be altered without repeated 
pramjyts. Any error detect ed by DEBUG during processii^ prevents the alteration of the location being 
processed. Pressing the (aLT MODE) key terminates the ALTER without storing the last value. The 
value of the last prompt is the new current location. 

The following example describes altering locations 2212 through 2215: 

- A 2212, 0000, OCDD, 00F7, 80EB (CR ) 

The followii^ example describes the use of the ^f) key and the (cr) key to control and terminate 
an ALTER operation: 



-A12A, 5133 (L 
012B 8 S 



012C 'AA' (CR 



In the above example, after altering location 012A, DEBUG responds with the address offhe next location to 
be altered (012B). Without further initialization, the value 8 is entered. The second ^^F) causes DEBUG 
to again prompt with the next available location to be ajtered (012C). The ASCH characters AA are entered 
and the ALTER operation is then terminated with a ^R) . The final prompt (-) signals the user that 
DEBUG is ready for another command input. 



1-6 



1,5.5 HALT 



-H <memory address> [ , <hexadeciinal number>] 

HALT terminates control by the user's program at the location specified by the memory address and returns 
control to DEBUG, The hexadecimal number (optional), if specified, is the number of times to pass through 
this location before halting execution. The instruction at the given location is not executed when execution of 
the user's program is terminated; the instruction is normally executed immediately after control is returned 
to the user's program by use of the GO commaBd, 

The HALT command can be used successfully only when the instruction at the HALT location and the instruction 
at the followirg location always are executed consecutively. Thus, the instruction at a HALT location 
cannot be either a skip or a transfer such that the instruction at the following location would not be executed 
consecutively. Execution of the HALT does not remove it from the user's environment. It is in effect each 
time that the instruction at the specified location is executed, 

NOTE 

DEBUG allows the user to set up to seven HALTS and/or SNAPs. If the user attempts 
to specify an eighth HALT or SNAP, DEBUG responds with an OV and refuses to 
accept the command. 

All registers are saved by DEBUG when it is entered and restored upon a GO command. The register stack 
must have one location for the DEBUG HALT execution. Upon halting, DEBUG prints CLxxxx, where xxxx 
is the location of the halt. 

For example, a breakpoint halt is required, in the user's program, at location 200, However, if it is 
desired to halt only after the fifth pass past that point in the routine, the command may appear as follows: 

-H 200, 5 (cr) 



1,5.6 SNAP 

-S <memory address> , <address argument> [, ,,,] 

Each time the memory location specified by the memory address is encoimtered, the contents of the ranges 
specified by the address argument are typed at the terminal in hexadecimal form. 

The SNAP can be used successfully only when the instructions at the SNAP location and at the next location 
always are executed consecutively. Thus, the instruction at a SNAP location cannot be either a skip or a 
transfer such that the instruction at the following location would not be executed consecutively. Execution 
of the SNAP command does not remove it from the user's environment. It is in effect each time that 
instruction at the specified location is executed. The user may type any character during the SNAP output 
to teirminate the output and the DEBUG prompt is issiied (as if a HALT occurred at the SNAP location), 

NOTE 

DEBUG allows the user to set vp to seven HALTs and/or SNAPs, If the user attempts 

to specify an eighth HALT or SNAP, DEBUG responds with an OV and refuses to accept the 

command. 

For example, if the user wishes to see the contents of arithmetic register AGO and the contents of memory 
addresses 145 throi^h 148, each time the user routine reaches address 224A, the following SNAP command may 
be used: 

-S224A, RO, 145:148 (cR) 
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The following is an example of tiie output tiiat is printed by DEBUG each time the specified address is 
encountered: 

CL 224A 

ROOOO 1234 

0145 FFFF 1234 5678 9ABC 
V ^ ; 

typical data 

1.5.7 GO 

-G <memory address^ 

The GO command initiates transfer of control to the user's program at the location specified by the optional 
memory address, IE no memory address is specified with the GO statement, the program continues at the 
last HALT location. All registers are restored in either case. 

To start a user's program at location 2600, the following GO statement can be used: 

-G2600 (CR) 



To continue execution after a HALT, the following GO statement can be used: 
-G (cb) 



1.5.8 MOVE 

-M <value> , <(address argument> 

A selected hexadecimal number or ASCII character pair is placed in the specified range of memory addresses 
or registers. 

For example: 

- M'XX*, 250:25F (cr ) loads aU locations with XX 
and - M 0, 250:25F (cr ) puts zeros into the range of locations 

1.5.9 NOTE 

-N <comment> 

The NOTE command permits the user to comment his debugging. AU text prior to the carriage return or the 
line feed is printed on the terminal. No other action is performed. 

For example, a NOTE comment may api>ear as follows: 

- N A COMMENT MAY BE PLACED AFTER THE N 
-N AND SUBSEQUENT LINES MUST ALSO BE 6r) 



-N PRECEDED BY AN N. ^ 
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1.5.10 FIND 



-F <value> , <address argvunent> 

The locations in the range of address argument are searched and the first location that is equal to the value 
is typed. If there is no match, DEBUG simply reprompts. The current location is either the location found 
or the last location searched. 

To find the pair of ASCn characters *LK» in the first 4K of memory, the following command may be used: 
-F'LK', 0:FFF (cr) 



DEBUG responds with the followiig output: 

CL OAAA if the characters are located at memory location AAA, 

To find a hexadecimal number, the following command may be used: 
-F 48, 0:FFF (cr) 



The first 4K of memory is searched. If the number is not found, DEBUG reprompts. 

1.5,11 RESET 
-R 

The RESET command causes all of the SNAPs or HALTs to be removed and the original code replaced. 
For example: 

"R (cr) 



1. 5. 12 CARRIAGE RETURN (CR 

Typing only the carriage return causes typing of the current location (CL) in the format (ASCn/hexadecimal) 
of the last command. 



1.5.13 LINEFEED ^ 

Typing only the line feed causes typing of the current location plus one (CL+1) in the current format. 
The current location is also increased by one. 



1.5.14 BACK ARROW 




Typing only the back arrow causes typing of the current location minus one (CL-1) in the current 
format. The current location is decreased by one. 

lo 5. 15 Summary of Commands 

Table 1-1 lists the commands in alphabetical order. 
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Table 1-1. Summary of DEBUG Commands 



Sjnnbol 


Command 


Structure of Statement 


A 


ALTER 




A 


j <memory address> ) 

1 <reglster address> j » < liexadeclmal number> 


C» ^•••) ^•••)J 


C 


CHAR 




C 


<address argument> [, <address argument> . 


..]■ 


F 


FIND 




F 


<value> , <address argument> 




G 


GO 




G 


<memory address^ 




H 


HALT 




H 


<memory address> , <hexadecimal number> 




M 


MOVE 




M 


<value> , <address argument> 




N 


NOTE 




N 


<comment> 




R 


RESET 




R 








S 


SNAP 




S 


<memory address) , <address argument) [, , 


..J 


T 


TYPE 




T 


<address argument) [, <address argument) , 


..] 


@ 


Type Current Location 


(CL) 








@ 


Type Next Location 


(CL+1) 






e 


Type Previous Location 


(CL-1) 
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IMP-16 LOADERS 



2. 1 INTRODUCTION 

The IMP-16 loaders are a compilation of programs that read and load one or more Relocatable Load Modules 
(RLMs), produced by the IIMP-16 Assembler, into the main memory for execution. Each of these programs is 
introduced briefly below and then is described in subsequent sections of this manual. 

Absolute Paper Tape Loader (ABSPT) is a stand-alone program that reads GENLDR (or any other singje RLM 
not requiring relocation) from the paper tape reader and loads it into main memory for execution, ABSPT is 
permanently resident in the IMP-16 ROM. Paper tapes read by the IMP-16 are assximed to contain eight 
channels of binary data. An RLM appears as a series of records of binary data in standard format (IMP-16 
Programming and Assembler Manual); each record is preceded by a Start of Text (STX) character and 
separated by Null -characters, 

ABSCR is a stand-alone program that reads any RLM not requiring relocation from the card reader and 
loads the program into the main memory for execution. The primary use of ABSCR is to load GENLDR. 
ABSCR is loaded into the main memory of the IMP-16L for execution by the Card Reader Bootstrap Loader 
(CRBOOT) but is permanently resident in IMP-16P ROM. 

CRBOOT is a stand-alone program for the IMP-16L and is not required for the IMP-16P. It is bootstrapped 
directly into main memory for execution under control of IMP-16L equipment. 

General Loader (GENLDR) is a self-contained IMP-16 program and performs the fdlowing functions: 

• Reads and loads one or more RLMs from the card reader and/or the Teletype. 

• Relocates the modides. 

• Resolves external linkages between the modules, 

• Provides descriptive information describing memory, globals, 

GENLDR is command-driven and provides comprehensive control over the loading process, GENLDR has 
the capability to change the loading input device. Otherwise loading proceeds in sequence from the device 
xipon which it was initiated. 



2.2 ABSPT (ABSOLUTE PAPER TAPE LOADER) 

ABSPT loads GENLDR or any other RLM (not requiring relocation) into the IMP-16 main memory from the 
paper tape reader. 



2.2.1 Usage 

The RLM tape loaded by ABSPT is an 8-channel tape, composed of successive RLM records, each preceded 
by a Start- of-text (STX) character. Since each record contains its own length, no extra characters may 
appear within records, but any character may appear between records. 
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2,2.2 IMP- 16 Loading 

ABSPT is resident in Read-only Memory (ROM) on the IMP- 16. The procedure for loaxiing paper tape is as 
foiQows: 

1. Press the INITIALIZE button on the MP- 16 panel. 

2. Place the RLM paper tape into the paper tape reader. 

3. Press the LOAD PROG button on the IMP- 16 panel. 

4. Turn on the paper tape reader. 

The RLM is loaded, the entry point address transferred to AC2, and the processing halted. At this point, the 
user can perform one of the following actions: 

1. Press RUN to cause execution of the program loaded. 

2. Alter the entry point address contained in AC2 and press RUN to cause e^cution to start 
at the modiGLed entry point. 

3. Load another RLM in the same manner as before. No resolution of inter-RLM linkages is 
performed; the user is cautioned to ensure that an RLM does not overlay a previously loaded 
module. 

ABSPT checks only for a checksum error and halts if one is discovered. To retry the load, position the 
paper tape at the beginning of the record in error; press RUN; and turn on the reader. In order to ignore 
the error, press RUN. 



2. 3 ABSCR (ABSOLUTE CARD READER LOADER) 

ABSCR loads one or more RLMs (which do not reqxiire relocation) into the main memory from the card 
reader. In the IMP-16L, CRBOOT is used to load ABSCR into memory; because of this close relationship, 
CRBOOT is described under the current heading. Refer to figure 2-1 for a description of a sample deck 
using CRBOOT and ABSCR. 




TERMINATES LOADING BY ABSCR 



ONE OR MORE RLMs 



ASTERISK (*) IN COLUMN 1 
ABSCR 

—I } CRBOOT LOADS UNTIL ASTERISK (*) CARD FOUND 



Figure 2-1. Example of Card Load by ABSCR 
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2, 3. 1 Usage 



In the IMP-16P, ABSCR is resident in ROM. In the IMP-16L, it is resident in memory, starting at the 
location specified by the user, and using ES^g words. ABSCR cannot load RLMs into memory location 
which it occxq)ies. 

The RLM card deck loaded by ABSCR is punched one card per RLM record; columns 73 through 80 of the 
card are ignored. Only the characters 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, and blank are 
allowed in columns 1 through 72; a blank is treated as a zero. Each record is the hexadecimal character 
equivalent of an RLM record as output by the IMP- 16 Assembler (see IMP- 16 Programming and Assembler 
Manual). 

2.3.2 RLM Loading 

The sequence of events for loadii^ an RLM, which contains nonrelocatabLe coding, from the IMP-16L 
card reader is as follows: 

1. Place CRBOOT in the card reader, followed by ABSCR, followed by the RLMs to be loaded, 
and a !G0 card. 

2. Press INITIALIZE, 

3. If ABSCR is to be loaded at other than location 120ie, perform the following steps: 

a. Set Mode Switch to ACQ. 

b. Set ABSCR load address into switches. 

c. Press LOAD DATA. 

4. Press AUXl. 

5. Press RUN, 

The sequence of events for loading RLMs from the IMP-16P card reader is as follows: 

1. Place the RLMs into the card reader followed by a !G0 card and ready the card reader, 

2. Press INITIALIZE. 

3. Set MODE Switch to PC. 

4. Set X»7F00 into switches. 

5. Press LOAD DATA. 

NOTE 

The following step must be performed; otherwise the system halts. 

6. Set MODE Switch to PROG DATA. 

7. Press RUN. 

As shown in figure 2-1, ABSCR continues to load RLMs until the !G0 card is encoimtered. When this occurs, 
if a nonzero entry point is specified in the last RLM, ABSCR loads AC3 with a 1 to indicate that the load 
device is the card reader and transfers control to the specified entry point. 
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If the last specified entry point is a '0' (supplied by the assembler as a default value), ABSCR halts. (See 
Error Code 5, below.) At this point, the user may enter the correct entry point into ACl and press RUN. 

When the user loads more than one RLM, no resolution of inter-RLM linkages is performed; the user is 
cautioned to ensure that an RLM does not overlay a previously loaded module. 

When ABSCR detects an error, it places an error code in ACO and halts execution. The following codes 
comprise the error codes: 



Code 



Description 



l/O Error - A transmission error or data overrun condition occurred on the 
card reader. In the IMP-16P, this code is the result of a motion error. 
The status word returned from the reader is placed in ACl before 
halting. To reread the card, replace the card in the reader and press 
RUN. 



Invalid Character - Only punches for 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, 
D, E, F, and blank are allowed in card columns 1 through 72. Correct the 
card; rerplace it in the card reader; and press RUN, 

Checksum - The checksimi calculated by ABSCR did not match that found on the 
last card read, indicatii^ either a read error or a bad card. Correct the card; 
replace it in the reader; and press RUN, 

Invalid Entry - The last END record read contained an entry-point address 
of '0' and a !G0 card was read. Place the correct entry-point address 
in ACl and press RUN, 



2,4 CRBOOT (CARD READER BOOTSTRAP LOADER) 

CRBOOT is the caxd reader bootstrap program for the IMP-16L, Its sole purpose is to load a singje 
program that is punched onto cards in a specific format. Typically, it is used to load ABSCR. 



2, 4. 1 Usage 

CRBOOT reads successive cards containing only hexadecimal characters 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 
A, B, C, D, E, F, or blank in columns 1 through 72; blank is treated as a zero. Characters are converted 
to their 4-bit hexadecimal equivalents, packed 4 characters to a word, and stored in successive memory 
locations. CRBOOT passes control to the loaded program (at the first location loaded) when it reads a 
eai^ with an asterisk (*) in column 1, (The rest of that card is ignored,) When it transfers control, 
interrupts are disabled. 



2. 4, 2 Bootstrap Procedure 

The following procedure shoidd be performed to bootstrap from the card reader: 

1, Press INITIALIZE. 

2, Place CRBOOT in the card reader, followed by deck to be loaded (typically ABSCR) and a 
card containing an asterisk (*) in column 1, 

3, If deck is loaded at other than location 120 ^g. perform the following steps: 
a. Set Mode Switch to ACO. 
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b. Set load address into switches, 

c. Press LOAD DATA, 

4, Press AUX 1, 

5, Press RUN. 

Note timt because CRBOOT resides in memory words 0 through 4Fj^g and uses words SO^g through QFj^g as 
an input bujEfer, CRBOOT cannot load a pr<^ram into locations 0 through SF^g^ 

CRBOOT halts at location OOlO^g if it detects a transmission error or a data overrun condition on the card 
reader; the entire load process then has to be repeated, 

CRBOOT halts at location 0020j^g if it detects an invalid punch. (Only punches 0, 1, 2, 3, 4, 5, 6, 7, 8, 
9, A, B, C, D, E, F, and blank are allowed.) Correct the card and repeat the entire load process, 

2, 4, 3 Format of CRBOOT 

Since CRBOOT is read by the IMP-16L equipment card reader bootstrap, it must be punched in a special 
format. 

Each (odd, even) pair of card colximns is packed into one memory word. Rows 2 through 9 of the odd- 
numbered column are moved into bits 15 through 8; rows 2 through 9 of the even-numbered column are 
moved into bits 7 throtigh 0, The hardware bootstrap reads one card, packs it into words 0 through 39iq 
{27 iq), and passes control to word 0, 

CRBOOT is a 2-card bootstrap (see figure 2-2). The first card contains the instructions necessary to 
read the second card, which has the same format as the first card. 



/ CRBpOT #1 ■ 

5/31/73 

e 0 r G 0 0 0 c s 0 0 0 c a 0 s 0 0 a a 0 0 0 0 a 0 0 0 D a 0 0 c n 0 G 3 3 c 0 u G r n 0 0 s E a c n s D 0 1 0 0 0 c D 9 0 G 3 3 Q a 0 c !! c s u c 0 : :: G a 
1 1 1 1 1 1 1 1 1 11 1 n 1 1 1 1 1 1 1 1 1 1 1 1 1 1 11 1 1 1 1 1 1 n 1 1 i n n 1 11 1 1 1 1 n 1 1 1 1 1 11 1 11 1 1 1 1 11 j 1 1 ni 1 i 1 1 

2|2|22|22222|22 2222222227222222222 ?22l .1:3222 2 222:1:12222222722 22:|2|2 2:1:1: 2222 
3 3 3 3 3 3 3 3 13 3 3 3 3 3 n 3| 3 3 3 3 3 3 3| 3 3 3 3 3 3 : 3 3|| :ll ? 3 J 3 'II : 3 3| :| 3 3 : 3 3 :>l :l -| : 3| 3|| 1 3l :|| :| : 
|44 4 4 4 |44|i4 44|44|4 4 4 <4 4|44< 4 4 ;'J ; 4C<| 'I'! ■^;.. 4 4 4 <| ;< < • ,41 4 44 4 4 4 4i 4| 4 4 4 4 «i'^4 4 4 
| 5 5 5| 5 5 5 5 5 5 5 5 5 5 |S 5 5|5 5l 5 5 5 ;I J :i 3 5 ; 5 Sllll 5 i 5 5 v 3 bl 5 5 d| 5 J :J j 5 5 5 5 5 i 5 5 5 5 5 5 5 5 5 l j 5i 5| j 

se|36EEmilllS6 8E|3SG|E3l|ssslf;:l::li.il':6:::l:l|Ei:lilGE6j|Ej:lEsieirGEEilcr|: 

7;77I77?| 7 7 7 7 7 7|7?|7l7l|7l|7|7|7;i|,|i;|;//?7?|;;|;?|l|i|!i<i7ili7i7?7|777i777 J 

tS88S 8 3 8 S8S 8 8 8 8|38|Sll'!3Cl|ail88Si33::l.;;;s:|: 3 3 3 aE83S388S3S|88 j8ES|:|!S|!3£S?3i 
S||9||3 9 3 9 9| 9 9 9||3|3 9| A ! 9| 0 S 3 Ol <! S t 'ill 3 3 3 3 9 ! ; S J 3 3 9 9 S ;ll 9 <:l ! 9 Cl 3 9| 'i j 3| 



/ ~ — ~ CRBOOT #2 

5/31/73 

C0003000000C30(!lil!OI)OOIII)!10rODO!I133 3 93!100C!C!IDillOOG3C!!(!OC'lC3!!SC03l!3J(!OOC80300'"33'J 

1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 n 1 1 1 1 i 1 1 1 11 1 I n n M 1 11 II 1 1 1 1 11 1 11 1 1 ! 11 1 11 1 1 1 11 1 n 11 1 1 1 1 1 11 1 11 1 

2222222|22222|2i:22|222 22|2 2 2l2|2l:I:ii222 2i|:22i2 2l2 2|2??2i2|?2 2 2 22 2 2 22||2 2 232 2 
}3|3|3|||333|||i3333333 3||33||3|3 3||3|3||3 3 33i|3 3|||:333|f33i3 333333 33331133 3333 
44444«4|4444 4|4||||44444'|i44|4||«4|4|44 44i!4 44 44 4 4||||4 4 4|4 4||4|44<44 44|4(44«44 
|S5S'|5i|5S|5||5|SS|5|ES!iS||S|||||55ii|55|5|5 5 9 55S5S|5S55Si|SS|3|5|S 5 5 5 SS||SS5S!iS 
EE||6E||||SE|i||E|GEE|CE|||S||G|EG|GS|S||ESC|||ES||iEESS|C|E||C|GES5ISE6£||SiStSe 
n|;77|7|77||i7|7||7777 77||7|||7|7777777||77|777777|7 7|77 7|7 777|7|7 777 777|7 777 77 
|8l8IS8|||i|8||| 8 8 8 | 8 8 8 !i|38t|l8l388|tS|3B!|8 3|8!;|B|BaiE|8!8 8tg|a|BB8MB|i!ISE88 



Figure 2-2, Program Cards for CR Bootstrap 
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2.5 GENU)R (GENERAL LOADER) 



GENLDR is a stand-alone IMP-16 program that loads one or more Relocatable Load Modviles (RLMs) 
produced by the IMP-16 Assembler, performs relocation and resolves external linkages, and loads the 
RLMs into main memory for execution. 

Each RLM must be transcribed to punched cards or paper tape (ordinarily, on the same machine used 
for assembling IMP-16 Assembly Source programs). These RLMs, as well as the commands that 
control the loading process, are then inpat to GENLDR, RLM record formats are described in appendix A 
of the IMP-16 Assembler Manual, 

The paragraphs that follow describe the commands to control GENLDR and the input sequences required 
to load an executable program into the IMP-16 main memory. Error messages and diagnostic output of 
GENLDR are also described. 



2, 5, 1 Usage 

GENLDR is a nonrelocatable stand-alone IMP-16 program that must be loaded into memory by one of 
two absolute loaders: (1) ABSCR allows GENLDR to be iqput from cards and (2) ABSPT, from paper tape. 
Once loaded, GENLDR can accept input from either cards or paper tape; although, initially, it accepts 
input from the device from which it was loaded, 

GENLDR occupies approjdmately ITOO^q words of memory and is typically loaded into upper memory. 
Programs cannot be loaded by GENLDR into memory that it occiipies or uses for the symbol table it 
generates. However, GENLDR allows the user full use of base page. The memory layout is described 
in figure 2-3, 

The IMP-16 Assembler allows the user to allocate portions of his program in three ways: 

• At an absolute memory location 

• Relative to the origin of the base sector 

• Relative to the origin of the top sector 

Typically, absolute allocation is employed to assign locations dependent vrpon equipment (for example, 
interrupt entrance address) or to communicate with special-purpose routines. The base sector must be 
located such that it is contained within the first 256]^q (lOO^^g) locations of memory and typically contains 
data and pointers necessary for inter-RLM communication. The top sector may reside anywhere in memory 
(subject to the limitations mentioned above) and normally contains the main portion of the RLM. Care must 
be exercised to ensure that an absolute sector does not overlay a previously loaded base sector or top 
sector. (See lOBS and lOTS commands in the following paragraphs.) 

Two other limitations are imposed i5)on the base sector by the IMP-16 computer architecture and the 
method for resolving certain external linkages. First, any base sector variable that is referenced by an 
indexed instruction must be allocated to one of the first 7F locations of memory. Second, in resolving 
certain external linkages, GENLDR may force an indirect reference to a global variable through a pointer 
in the memory area FF^g and downward. 

The area of IMP-16L memory between locations 100 j^g and llF^g is used by the control panel service 
routine and may not be used by the user. Above address FP^g, loading is limited, only within the area 
occupied by GENLDR and the symbol table it generates, (This area may be used by the loaded program, 
after it receives control from GENLDR.) 

As an entry point, GENLDR selects the last nonzero value specified for the set of RLMs loaded. The entry 
point for any particular RLM, if specified, appears in the END record of that RLM, If the user desires, he 
may override the entry point selected by GENLDR by specifying the desired entry point in the !GO command 
(paragraph 2, 5, 17), If neither of these methods is chosen, GENLDR prints an "ENT" error message and 
prompts for a new command. 
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GENLDR 



SYMBOL TABLE 



ABSOLUTE SECTOR 



TOP SECTOR. 



TOP SECTOR, 



INDIRECT POINTERS 
GENERATED BY LOADER 



BASE SECTOR. 



BASE SEUTUR- 



7 



HIGH MEMORY 



100 



16 



FF 



16 



00 



16 



Figure 2-3, Mraaory Map 
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2. 5. 2 GENLDR Input 



GENLDR is conmiand-driveru It reads cammands and RLMs from either cards or paper tape, and cofmmands 
are available to switch between input devices. (See ICR and ITTY, paragraphs 2. 5. 9 and 2, 5. 10). GENLDR 
does not recognize BXiy distinction between the Teletype paper tape reader and the Teletype keyboard; therefore, 
the user may type in his cammands at the keyboard and input the RLM from paper tape. Cammands entered 
either on paper tape or the keyboard are echoed back to the Teletype printer; the RLM itself is not echoed. 

Commands entered on punched cards must contain an exclamation point (!) in column 1, When the command 
is entered from the Teletype, GENLDR iypes the exclamation point to prompt for a command. The user 
should not type the exclamation point. 

Input lines on the Teletype can be terminated by either a carriage return or a line feed. GENLDR supplies 
a line feed if a carriage return is issued, or a carriage return if a line feed is issued. GENLDR recognizes 
the following special characters when reading from the Teletype; 

< Backspace character 

ALT MODE Delete entire line 

RUB Riibout character (ignored) 

NuU character (ignored) 

A maximum of 72 characters is allowed in one Teletype input record; excess characters are ignored. 



2.5.3 GENLDR Output 

GENLDR may be directed to print information descriptive of the loading process. The title information, 
base sector limits, top sector limits, absolute sector limits, indirect pointer limits, and entry point 
address of each RLM may be printed on the Teletype (see !LM command). The user may also request the 
printing of the symbol table, or only those entries of the symbol table that refer to undefined (U) or multiply- 
defined (M) symbols (see !SY and !ER canamands in the foUawing paragraphs). 

If ILM is issued, GENLDR types the following information at the end of each RLM: 

MNEMONIC QUALIFYING STRING AAAA BBBB 

BS=XXXX:XXXX TS=XXXX:XXXX AS=XX5CX:XXXX PTR=XXXX:XXXX ENT=XXXX 

where: 

• MNEMONIC is the name of the RLM from the TITLE record, 

• QUALIFYING STRING is the qualifying string from the TITLE record. 

• AS specifies the low and high addresses of the absolute sector. 

• BS specifies the low and high addresses of the base sector. 

• TS specifies the low and high addresses of the top sector. 

• AAAA and BBBB are the RLM source and object checksums, respectively. 

• PTR is the number of indirect pointers generated. 

• ENT is the entry address from the END record. 
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All numbers are printed in hexadecimal notation^ If INLM is the last command issiied (of !LM or INLM), 
when !GO is executed, one line of the above format is output containing composite limits of all RLMs 
over the scope of the INLM command. 

If !SY or !ER is specified (or defeiilted), GEKLDR prints symbols as follows: 

SYMBOL XXXX F 

where: 

• SYMBOL is the symbol name. 

• XXXX is the hexadecimal address of the symbol. 

• F is one of the following: 

M- multiple -defined symbol 
U - undefined symbol 
blank - defined symbol 

2.5.4 GENLDR Commands 

All commands must begin in coltrain 1 of tiie input record. One or more blanks must separate the command 
from an operand. Unless otherwise specified, where the term < hex-value > is used below, it represents a 
• hexadecimal number in the range 0000 to FFFF, Leading zeros need not be specified, but no more than 
four hexadecimal characters can be given for < hex- value > , 



2.5.5- I OBS - Origin Base Sector 

!OBS <hex-value> 



NOTE 

Ojg <= hex-value < = FF^^g. If this command is not given, the first base sector is 
l(^ed at location lOj^g. 

The origin for the next base sector is set to < hex- value > , If this command is not specified, the next 
base sector is loaded immediately following the previous base sector. This command should be used to 
prevent loading a base sector on top of an absolute sector. 



2. 5. 6 ! OTS - Origin Top Sector 

!OTS <hex-value> 



NOTE 

The highest value of < hex- value > is a function of the memory available, and must 
not cause overlayiiig of the locations occig)ied by the symbol table or GENLDR. If this 
command is not given, the first top sector is loaded at location 120 j^g. 

The origin for the next top sector is set to < hex-value > , K this command is not specified, the next top 
sector is loaded immediately following the previous top sector. This command shoidd be used to prevent 
loading a top sector on top of an absolute sector. 
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2. 5. 7 IRLM - Relocatable Load Modtde Identifier 

IRm 

This comraatid must precede each RLM to be loaded. The RLM is loaded from the same device from which 
the RLM command is entered. 

2. 5. 8 ICLR - Clear Memory 

ICLR 

Memory below GENLDR is cleared to zeros if this command is issued before the first RLM is loaded. 
After loading is completed (that is, a !GO command is read), memory containii^ the symbol table and 
GENLDR is zeroed; this latter function is performed even if the ICLR command is issued after an RLM 
is loaded. 

2. 5. 9 ICR - Read Input fcom the Card Reader 

ICR 

Subsequent input is accepted from the card reader. 

2. 5. 10 ITTY - Read Input from the Teletype 

ITTY 

Subsequent input is accepted from the Teletype, Teletype iaput is accepted from either the paper tape or 
the keyboard, but only commands are echoed to the Teletype printer. 

2. 5. 11 I SY - Print the Symbol Table 

ISY 

The symbol table is printed upon execution of this command. 

2. 5. 12 lER - Print Symbols in Error 

lER 

Multiply-defined and undefined symbols are printed when this command is read. 

2. 5. 13 ILM - Print Limits 

ILM 

As each RLM following the ILM command is loaded, GENLDR prints the name, checksums, base sector 
limits, top sector limits, and absolute sector limits of the RLM, Each time RLM limits are printed, 
they are reset so that a record of areas occupied by only sir^e RLMs is maintained by the program. The 
default command is INLM. 
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2. 5. 14 ! NLM - Don*t Print Limits 



!NLM 

The name, base sector limits, and top sector limits are not printed. Instead, when a !GO command (2.3.4, 13) 
is executed, GEKLDR prints the combined base sector limits, top sector limits, and absolute sector limits 
of all programs loaded. The default command is !NLM. 



2. 5. 15 !SQ - Check Sequence Numbers on Input Deck 

!SQ 

After this command is executed, the sequence number field of each iiqjut card (columns 73 through 80) 
is tested to ensure that the sequence numbers contained therein appear in ascending order from one card 
to the next. If they do not appear this way, an error mess^e is printed. The defaidt command is !NSQ. 

2. 5. 16 !NSQ - Do Not Make Sequence Number Check 

!NSQ 

Execution of this command nullifies the execution of an ISQ command. The de&ult command is !NSQ. 



2. 5. 17 I GO - E^cute the Loaded Program 

!GO < hex- value > 

The entry point specified in the last KLM loaded can be overrriden by specifying the entry point address 
(" < hex-value) "), If < hex- value > is omitted, the last nonzero entry point specified is executed. 
If no nonzero entry point is specified and no value appears in the command, GENLDR prints an error message 
and returns to the command mode. If a ICLR command is previously read, the symbol table and memory 
containing GENLDR are zeroed before execution of the loaded prc^ram. Before transfer to the entry point, 
the combined limits of all programs loaded are printed on the Teletype if the individual program limits are 
not printed. 



2. 5. 18 Messages 

The following messages may be output by GENLDR: 
GENERAL LOADER (REV, X) READY. 

GENLDR is ready to accept ccnxonands. X is the current revision level of GENLDR. 

CMND The command is invalid or imrecognized. Reenter the command. 

CHAR An RLM record contains characters other than 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, 
B, C, D, E, and F. Correct the record; reload; and press RUN, 

SEQ Record sequence error. The correct sequence is (1) Title Record, (2) Zero or more 
Symbol Records, (3) Zero or more Data Records, and (4) End Record. Correct 
record sequence; reload; and press RUN. 

CKSM Checksum error on the next>-to-last record read. If the checksiim field is 0000, no 

checksiim test is made. The read may be retried. Reload the record and press RUM, 
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NMBR A sequence number error is detected. Place the input cards in the correct order and 
restart, or continue. 

BSOV Base sector overflow. The run must be restarted, but the error may be corrected by 
proper use of OBS and OTS commands, 

TSOV Top sector overflow. The run must be restarted, but the error may be corrected by 
proper use of OBS and OTS commands, 

SYMB Symbol table overflow. Too many external symbols defined. The run must be restarted, 
but the error may be corrected by proper use of the OTS command, 

ADDR Addressing error. This error occurs under the following conditions and the run must 
be restarted: 

1, Attempting to reference an indirect pointer generated by the assembler which, because 
of relocation, is forced to an address greater than 255]^q (FF^^g), 

2, Usir^ an index register in an instruction referencing a base sector variable allocated 
to a memory address between 128j^q (SO^g) and 255^^ (FF ^g), 

3, Attempting to use an index register in an instruction referencing an undefined external 
variable. 

4, Referencing an undefined external variable in an instiruction which either is flagged 
indirect already or cannot be so flawed. 

EXTN Unable to locate external symbol in Symbol Table. This error may be caused hy 

attempting to load an RLM with some missing symbol records or by an erroneous patch 
which looks as if it is referencing an illegal external reference number. The run 
must be restarted. 

AREA Loading in illegal area possibly on top of the loader). Restart with valid ! OBS or ! OTS 
commands. 

MEM Memory size exceeded. Loading into nonexistent memory. Recovery not possible, 
but error may be corrected hy proper use of OBS and OTS commands. 

SYST System error caused by a malfunction in system software or hardware. Recovery not 
possible, 

PNCH Invalid punch in impat record. Only the characters: blank, 0, 1, 2, 3, 4, 5, 6, 7, 8, 
9, A, B, . . , , X, Y, and Z accepted. Correct; reload recorc^ and press RUN. 

CRDR 1, Card reader is offline. Place reader online and press RUN, 

2. Transmission error or data overrun on card reader. The status word returned by 
the card reader is in ACO. Replace card in reader and press RUN. 

ENT No entry point specified for program. GENLDR transfers contrd. to the Teletype for 
new command. 

DROP Card dropped out of deck (that is, sequence number incremented by more than 10 and 

I SQ in effect). Check last two cards read. If there are no cards missing between them, 
press RUN; otherwise, correct card deck and reload, 

PTCH nnnraumn 

A patch card (card with sequence number that is not a multiple of 10) with sequence number 
'nnnnnnnn' was processed. 
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2. 5. 19 Sample GEKLDR Run 

The sequence of a sample IMP-16L GENLDR run is shown in figure 2-4. The sequence starts with CRBOOT 
and proceeds through the steps shown to !GO, vtpon which execution of GENLDR starts at location 2882^q ^^^^ir) 
When GENLDR is run on an IMP-16P, CRBOOT and ABSCR are not required in the sample deck. 




START EXECUTION AT 
LOCATION 120j^g 



PRINT SYMBOLS IN ERROR 



!CR 



!LM 



-i TRANSFER CONTROL TO CARD READER 
' — FOR FURTHER COMMANDS 



3 



PRINT LIMIT INFORMATION 




TRANSFER CONTROL TO TELETYPE FOR 
FURTHER COMMANDS 

CLEAR MEMORY TO ZEROS 

!G0 FOR TERMINATING ABSCR INPUT 



CARD READER BOOTSTRAP AND THE 
ABSOLUTE LOADER LOADS GENLDR 



(CONSISTS OF TWO CARDS) 



Figure 2-4. Sequence of Sample IMP-16L GENLDR Run 



Chapter 3 
TELETYPE I/O ROUTINES 

3. 1 INTRODUCTION 

STTYIO contains jSve Teletype ii^ut/output routines assembled in one relocatable object program. Each 
routine performs one commonly used Teletype function. 

3.2 USAGE 

A transfer vector is reserved in base page to establish a Sxed interface between user and STTYIO 

3.2.1 Functions 

The five Teletype functions in STTYIO are: 

• SETPL Resets the Teletype and initializes the other four routines for IMP-16L/16P 

operation. 

• INTEST Tests for Teletype ii^. 

• PUTC Transmits bits 0 - 7 of Accumulator 0 (ACO) to the Teletype. 

• GETC Transfer from Teletype to bits 0 - 7 of Accumulator 0 (ACO). 

• GECO Same as GETC plus an echo of the character on the Teletype printer, 

3. 2. 2 Cammimications 

The user may call these routines by using the JSR@ instruction and the transfer vector reserved in base 
page. Addresses in base page are reserved as follows: 

OOOB SETPL 

OOOC INTEST 

GOOD PUTC 

GGOE GETC 

GGGF GECO 

For example, to transmit bits 0 - 7 of ACO to the Teletype, the following instruction may be included in the 
instruction stream: 

JSR @X'D 

When using INTEST, return from the routine is as follows: 

CALL+1 INPUT AVAILABLE FROM TELETYPE 
CALL+2 NO INPUT FROM TELETYPE 
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A typical user's program usir^ INTEST may appear as follows: 



JSR 

JMP 
JMP 



ATTINPUT 
NOINPUT 



; ATTEMPT TO INPUT 

;NO INPUT FROM TELETYPE 



Return from all the other routines is RTS 0. 



3.2.3 Limitations 

When STTYIO is loaded in memory, locations X'B through X'F in base page are reserved locations. SETPL 
must be called prior to use of any of the other four routines. Registers and flags are not altered by any of the 
five routines except AGO in GECO and GETG. The stack is pushed three levels deep during execution of 
these routines. 

These routines are dependent on system speed. They are good only at normal system speed (1.4iasecoad per 
microcycle). 



3. 3 LOADING 

STTYIO may be loaded by the absolute card reader loader, absolute paper tape loader, or the general 
loader. Refer to chapter 2 of this manual for additional information concernii^ IIVIP-16 loaders. 



3. 4 STORAGE REQUIREMENTS 



Base Page 



X'B through X'F 



Top Sector 



STTYIO is currently assembled top sector relocatable and 
occupies 123j^Q C^^ie) words. 
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Chapter 4 



FIRMWARE PAPER TAPE GENERATION 



4. 1 INTRODUCTION 

PROMP is a program that generates paper tapes for PROM programming. It has the following capabilities: 

• Punch PN format PROM tape. 

• Punch BC (binary complemented) format PROM tape, 

• Punch paper tape RLM from card RLM. 

PROMP output tapes for ROM programming are used only in ROMs programmed 8-by-256 bits (used in 
multiples of two). 

4. 2 PROGRAM ENVIRONMENT 



4.2.1 Program Loading 

PROMP may be loaded by GENLDR or by the absolute loader (ABSCR), when PROMP is in card deck object 
format, and by the LOAD PROG function in the IMP- 16 when PROMP is in paper tape object format. PROMP 
uses the Teletype I/O functions provided in STTYIO and thus requires that STTYIO also be loaded into memory. 



4.2.2 Memory Requirements 

PROMP requires 655jg words of top sector memory. 



4.2.3 Program Messages 

To guide the user in the use of PROMP, query messages are typed. There are four general messages 
corresponding to the four possible program states. Initially, PROMP types: 

NSC IMP- 16 FIRMWARE PAPER TAPE GENERATOR 
OUTPUT TYPE: 

The user must then respond with one of the following codes: 

PN - For PN format PROM tape. 

BC - For binary (complemented) format PROM tape. 
OM- For card RLM to tape RLM conversion. 

AH responses must be terminated by a carriage return. For the OM option, PROMP types the following 
message and goes into an output state: 

TURN PUNCH ON 

MAKE CARD READER READY 

At this point, RLM records are converted from card to paper tape. After processing the END record, 
PROMP goes into a wait state. The user may now turn off the Teletype punch. Typing any key returns 
the PROMP program to the initial state. 



In either PN or BC options, PROMP goes into an input state. The following message is lyped: 

INPUT DEVICE: 

The user may respond with one of the foUowii^ codes: 

CR - Card Reader 
PT - Teletype 
ME - Memory 

ME Option. If this device is selected, PROMP then types: 
SPECIFY MEMORY — 

The user must then type the memory range, where the user program is located. A range is designated 
by the start address and the last address, delimited by a colon (:); the range must be in blocks of 256 j^q 
512j^Q words. 

Example: 

SPECIFY MEMORY — FFOOrFFFF 

CR Option. PROMP types the following message: 

MAKE CARD READER READY 
TO LOAD RLM 

The card reader must be turned on at this point. 

PT Option. If this device is selected, PROMP types the message: 

MAKE TAPE READER READY 

TO LOAD OM 

After the loading process, when the END record is recognized, PROMP types: 

TURN READER OFF 
The user must turn off the reader and press any key to initiate the output process. 
After the loading process, PROMP goes into an output state and types: 

OUTPUT OPTION: 
The user must respond with one of the following codes: 




Default, options 1 through 4, below. 



1 



First 256 words, left byte. 



2 



First 256 words, right byte. 



3 



Second 256 words, left byte. 



4 



Second 256 words, right byte. 
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If more than one option is desired, the user may type options consecutively, delimiting with either a 
comma (,) or space. After the option is typed, PROMP comes back with the message: 

TURN PUNCH ON 

HIT ANY KEY TO START 

After the output process, PROMP goes into its last state, the wait state. This wait state is provided so that 
the user can turn off the ptinch before any message is typed by PROMP, To return to the initial state, the 
user must press arsy key on the keyboard, 

Typii^ CTRL/D when PROMP is waiting for a response transfers the user to the initial state. Leaders/ 
trailers are punched automatically. If PN is chosen as an output type code, pressing any key during the 
output process causes an interrupt of the current output option and initiates processing of the next output 
option, 

4. 3 INPUT/OUTPUT FORMATS 



4, 3, 1 Input Formats 

PROMP accepts object programs in RLM format and memory contents for i^put. Input device may be a 
card reader. Teletype, or memory. 



4. 3, 2 Output Formats 

There are three possible output formats from PROMP: PN and BC for PROM tapes, and RLM tapes. 

PN Format. In this format, 1 (one) bit is represented by one frame P (for 1) and N (for 0) in ASCII format. 
Each 8-bit block is preceded by the character B and followed by F, CR or LF precedes each B character. 

NOTE 

This format should be used when ordering ROMs or 
PROMs from National Semiconductor Corporation. 

BC Format, In this format, 8 bits (may be left or right) is represented by one frame. The frame contents 
is the binary complement, 

RLM Format, Refer to the IMP-16 Programming and Assembler Manual and chapter 2 of this manual for 
a complete description of RLM object programs. 



4,4 USAGE 

By typing the right codes in response to PROMP queries, the user can use PROMP in a variety of ways. 
The following table shows all possible input/output options. 
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Table 4-1. Input/Output Options 





Input 


Output 




Fimction 


Option 
uoue 


Input 


Input 
Format 


Option 
Code 


Output 
Format 


Option Codes 


RLM 
to 

PKUiVi 


CR 


Card 
Reader 


RLM 


PN 
BC 


PN 

Binary 


(UK ) , 1, O, 'i 


PT 


Teletype 


RLM 


PN 
BC 


PN 

Binary 


(cr) 1.2.3,4 




ME 


Memory 


Binary 


PN 
BC 


PN 

Binary 


(cr), 1,2, 3,4 


Card 
RLM 




Card 
Reader 


RLM 


OM 


RLM 


Not 

applicable 


to 














Tape 
RLM 
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Chapter 5 



EDIT16 



5. 1 INTRODUCTION 

EDni6 is a paper tape source editor program, used with the IMP-16L/16P processors, EDITie enables 
editing of a previously prepared source program (or any text) or generating and editing new text. Once 
loaded, the program is self-starting and provides approximately 4000 characters of working storage in a 
4K processor. 

The normal editing procedure is to input text, edit the text, and output the edited text. Refer to paragraph 
5.6 for a sample edit run. 

Prepared text, in punched paper tape format, is read in through the Teletype paper tape reader. New text 
is generated by taping lines of text on the Teletype keyboard. A line of text is a string of characters 
followed by a (CR) character. Output text is punched on the Teletj^e paper tape punch. 

EDIT16 commands are line oriented. Character editing capability is provided through the use of the "Modify 
Line/String" command. Automatic line reniraibering is performed when lines are inserted, deleted, and moved. 

Appendix E contains a table of the symbol meanings that are used in the discussions that foUow, 



5.2 COMMAND MODE AND TEXT MODE 

The EDIT16 is in the command mode when it types a prompt character and waits for a command input. 
Most EDIT16 commands operate in this mode, but there are a few commands that require additional 
information for the command to be carried out properly. In g etting thi s additionalmformation, EDIT16 
goes into a text mode. Text mode is terminated by either a (cTRL/Q ) or a (CR) depending on the 
command being processed. Command mode always follows successful command processing. 

If an invalid EDIT16 command is typed, the message ERROR is typed, followed by CR/LF, and then the 
prompt character (?), Note that only one command per line is accepted. 

All EDIT16 commajids are terminated by a (CR) , If the command is not a text-type command, processing 
starts after the (CR) character is typed and EDITie remains in command mode. If the command is a 
text type command, typing (6r) causes EDITie to go into text mode. 

Typing (CR) causes EDIT16 to respond with CR/^F; that is, a carriage return followed by a line feed. 
Note that when the keyboard is used as an input, fcR) signals the end of a line and also appears in the 
edit buffer as the last character of a line. 



5.3 COMMAND DELIMITERS 



5.3.1 Arguments 

Arguments are used in EDIT16 commands to specify' portions of the edit buffer vipon which the command 
operates. When a command requires an argument but none is typed, default values are called upon and these 
vary according to the command. EDIT16 uses the following arguments: 

n Is an unsigned decimal number from 1 to 9999. It denotes existing line numbers 

in the edit buffer. 
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/ Specifies the high and low values of a raage argument. 

TO Must be followed by n, and operates on n such that n signifies the destination 

in a transfer type command. 

m Number of lines coxmt: usually used in addition or insertion of new lines, 

» Single quote: used to enclose a string of characters for commands that require 

string arguments. 

The first four symbols may be combined in different formats to help the user achieve specific tasks. Valid 
combinations are as follows: 

Usually used to insert new lines into existing text, m gives the number of 
lines to insert before line number n. 

Same as above ex cept that the number of lines to insert before line number n is not a 
fixed amoimt, (ctRL/Q) is used to terminate insertion. 

Used in copy and move line commands, n-j^ is the line to be moved or copied and 
n2 is the destination line number. Note tMt both n^ and must be existing line 
numbers. 

Used to specify a line number range. 



5. 3. 2 Command Properties 

All commands are line oriented. Line numbers specified in a command argument must be lines existii^ 
in the edit buffer. Specifying non-existent lines causes abnormal EDITie execution, which may result 
in program crash. 

Arguments must be separated from the command by at least one space; although, some commands may 
execute properly even without command and argument separation. 

All valid commands are two characters loi^. 



5. 3, 3 The Edit Buffer 

The edit buffer contams the source text which is being edited. Each line is composed of a line number, 
line source, and a (CR) character. Source is packed, two ASCII characters per word, and repeated 
spaces are packed using a repeat coimt. The edit buffer is located on top of the EDm6 code such that 
its size is dependent on the machine memory space. 

5.4 COMMAND SET 

Commands are grouped into three sets: Iiqjut/Output Commands, Text Modify Commands, and Search 
Commands. 



5. 4. 1 KB - Keyboard Read 

The KB command is used to enter text into the edit buffer from the Teletype keyboard. EDIT 16 types -> 
whenever it is ready to accept a new line. Typing CTRL/Q as the first character in a new line terminates 
the keyboard entry and EDIT16 goes to command mode. 



m TO n 
TO n 
n^TOng 

n^/ng 
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Example: 



-> 
-> 

-> 



? KB (CR ) 
FIRST LINE (CR; 

(cntl/q) *** 



? KB 1 (CR 



APPEND ONE LINE {C 



? KB 2 TO 2 (CR 



-> 


FIRST INSERT ( 




-> 


SECOND INSERT 






? KB TO 3 




-> 


TfflRD INSERT 




-> 


FOURTH INSERT 




-> 


FIFTH INSERT 




-> 


(CNTL/Q) *** 











KB without an operand appends all text entered from 
keyboard. 



Append one line to edit buffer. 



Insert two lines before current line 2. 



Insert all text entered before current line 3. 



Next prompt. 



A description of the sjrtnbols used in these examples is included in appendix E, Typing (cNTL/q) when 
EDIT16 is waiting for a command initiates the keyboard input mode. 

Example: 



? (cntl/q) 



-> 



The current line being entered is ignored if (cntl/q) is entered before the ^r) . A back arrow 
deletes the last character typed, — 



5. 4. 2 RT - Read Paper Tape 

The RT command enters text into the edit buffer from the Teletype reader, but does not print the lines. 
This command processes input lines, similar to the KB command. To terminate text entiy when no fi xed 
number of lines is specified in the argument, the user must turn off the reader and enter a (cnTL/q) on 
the keyboard. The same action may be used to abort the entry. If the reader is turned off in the middle 
of a line, only the last complete line is transferred to the buffer. 

If the edit buffer becomes full when entering lines using the KB, RT, and RC commands, 
the message: 

BUFFER FULL 

is typed and EDIT16 goes into command mode. Again, an incomplete line is not entered to the buffer. 
Example: 

? RT 2 ^R ) Append two lines to the edit buffer. This message 

is typed after the second line is read. 

TURN READER OFF NOW 
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5.4.3 RC - Read Card 



The R.C command must be issued only when applicable. That is, on systems equipped with a card reader. 

It reads a card and treats it as one line. Arguments applicable to the KB command (refer to paragraph 5. 4. 1) 

apply here also. 

5.4.4 LS, LF, LL - Teletype List 

The LS command lists text on the Teletype. Listed lines are numbered. LF lists line number 1, the first 
line of text, LL lists the last line of text. 

Example: 

? L S 2/4, 6 (c5 ) Lists lines 2 through 4, and line 6 on the Teletype. 

? LS (CR ) Lists entire text. 

To inteTTvpt the list, press any key on the Teletype keyboard. 



5. 4. 5 PT - Punch Paper Tape 

The PT command is used to punch text on paper tape, 
message is typed: 

TURN PUNCH ON 



Immediately fdlowing the PT command, the following 



EDIT16 then goes into the wait state. To continue operation, turn on the punch and press any key on the 
keyboard. To interrupt the punch, press any key. The punch operation is interrupted immediately. At 
the end of the punch operation, EDITie goes to a wait state. Turn off the punch and press any key. Line 
numbers are suppressed. 

Example: 

? PT 1/3 ^R) Pvmch lines 1 through 3. 



? PT fcR} Punch entire text. 



5.4.6 TL - Punch Leader/Trailer 

The TL command pimches approximately 5 inches of null characters for use as trailer or leader. Note 
that the PT command does not provide for a leader or trailer. 



5. 4. 7 HP - High Speed Printer List 

The HP command must be issued only where applicable. That is, for systems equipped with a high-speed 
printer. HP provides the same output list format as the LS command (refer to paragraph 5, 4,4), 



5. 4. 8 MD - Modify Line 

The MD command enables character editing in a line. Characters may be inserted or deleted and lines 
may be trimcated or extended. 
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Examples: 



? MP 2 (CB ) Modify line 2. 

2 SECOND LINE Line 2 is typed back. 

ALTERS ? SECOND TEST LINE (cb) Line 2 is extended. 



^COND TEST LINE Ljne 2 is typed back. 

ALTERS ? fcR) CR) first character typed, means end of modify 

? line command. 



( CTRL/z ) followed by any character 'C advances the carriage to the first occurrence of 'C in that line. 
Example: 



? MD 2 (CR; Modify line 2. 



2 SECOND TEST LINE Line 2 is tvped back. 

ALTERS ? (CTRL/z) D (CTRL/z) , then D advances the carria ge to the 

first occurrence of the character D. (CTRL/z) 
and D are not echoed but the line is. 



ALTERS ? SECON 



Carriage stops here, where the D would have been. 



( CTRL/z) 'C may be issued at any point within ihe line as long as is present in the columns between 
the carriage and the last character of the line. 

Typing ( CTRL/x) ^on any column deletes the character in that column, A ' f ' is echoed on the printer 
for each ( CTRfTx) . 

Example: 

2 SECOND TEST LINE 'TEST' is to be deleted. 

ALTERS? SECOND fffff 
2 SECOND LINE 

Typing ( CTRL/a) inserts all characters typed after it, vtp to, but not including a (CR) . Characters 
inserted are enclosed by ' < ' and ' > ' . 

Example: 

? MD 2 (CR) Modify line 2. 



2 SECOND LINE 



ALTERS ? SECOND <TEST > (CTRL/a) typed - ' < ' echoed. 

2 SECOND TEST LINE typed - ' > ' echoed. 

ALTERS ? 



Typing a (ctrL/Q) aborts the current line modification. 



Typing a ( CTRL/p ) trtmcates the line. 
Example: 

? MD 2 (Cr) Modify line 2 



2 SECOND TEST L ENE 

ALTERS ? SECOND TEST QctRL/d) (CTRL/D) truncates rest of line, 
2 SECOND TEST 
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5. 4.9 MS - Modify Striag 



The MS command modifies lines like the MD command. The argument must be a character string enclosed 
in single quotes ('). H the string argument is not found in the text, EDIT16 merely prompts for the next 
command. 



Example: 



? MS 'SEC (pR ) 
2 SECOND LINE 

ALTERS? 



'SEC string is in line 2; thus, proceed to modify line 2. 



5. 4. 10 DL - Delete Line 

The DL command deletes a line or a range of lines. After the specified lines are deleted, EDIT16 automatically 
renumbers the text. 



Example: 



? DL 1,3/5 fcRj 



Delete lines 1, 3, 4, and 5. 



EDIT16 types 'VOID RANGE' when the specified line is out of rai^e. 



5.4.11 CL - Copy Line 

The CL command copies existing lines to anywhere in tiie buffer. Lines are renimibered automatically. 
Example: 

? CL 1/2 ^r) Append copies of lines 1 and 2 to the buffer. 

Insert copies of lines 3 and 4 before line 6, Line 6 
becomes line 8. 



? CL 3/4 TO 6 CR 



5. 4. 12 MV - Move Line 

The MV command moves lines to argnvhere in the buffer. Note that MV is like the CL command except that 
the lines being moved are deleted from their original locations. Lines are renumbered automatically. 



Example: 



MV 1 CR. 



This command results in line 1 becoming the last 
line and line 2 then becomes the first line - and on, 
throt^ the buffer. 



5.4. 13 CB - Clear Buffer 

The CB command clears the entire buffer. If an output command is issued and the buffer is clear, EDIT16 
types: 

NO ACTIVE FILE 
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5. 4. 14 FS - Find String 

The FS command searches the entire edit buffer for aU occurrences of the specified string. Lines 
containing the strii^ are typed, H no string is found EDm6 types: 

VOID RANGE 

It then prompts for the next command. Quote mark (') is treated just like any other character. 
Example: 

? FS 'ACl' ^ Find string 'ACl' in edit buffer. 

VOID RANGE No string 'ACl' in edit buffer, 

? FS 'XTF' ^ Find string X'FF in edit buffer. 

3 ,WORD X'FF FF found in line 3. 

? 



5.4.15 ST - Set Tab 

The ST command enables fixed horizontal spacing when collecting text in keyboard mode. 
Example: 

? ST ^ 

123456789%123 4..,.% 12345 
START? f _1_ _1_ _1_ 

VERIFY? / 1 1 1 

' Colirain 1 ' ' Column 65 ^ 

EDIT16 prints the row of niimbers, one character for each column. After 65 columns are marked in this 
manner, EDITie prints START?, The user then can mark iqj to three columns, where a tab is desired, 
with* any printable character (in fte above example, the number 1 is used). EDITie replies with a verification 
by typing a corresponding 1 in each position where a tab is specified. 



5,5 OPERATING PROCEDURES 



5. 5. 1 Startir^ 

The EDIT16 program may be loaded by the absolute loader or general loader and starts automatically. 
Once loaded, the following sequence occurs: 

NSC EDITie REV X 
MEMORY: 

Type in the memory range in the format 0:xx, where xx lies inflie range 4< xx < 64 and must be a multiple 
of 4, "xx" must not be greater than the actual system memory. To get the default of 4, type ^R) . 
EDIT16 repeats the message if input format is erroneous. If accepted, EDITie goes into command mode and 
types the prompt character (?). 
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5,5,2 Error Corrections 



EDIT16 processing may be interrupted by the use of the foUowii^: 



1. ( ctRL/q) aborts the current command input if in command mode, or the cxirrent line input 

if in text mode. 

2. Pressing any key on the keyboard during an input or output operation aborts processing and 
EDIT16 goes into command mode. 

3. Back arrow N-H , typed while in text mode, deletes the previous character input. Successive 
back arrows delete preceding characters in the line. Back a rrows ma y not be used in command 
mode or when inserting characters (characters typed after (cNTL/a ) ) in the modify line/ 
string commands, 

5. 6 SAMPLE OF EDIT16 USE 

The program, listed in figure 5-1 needs to be corrected; the corrections are shown pencilled-in. Figure 5-2 
shows the use of EDIT16 commands to implement changes to the sample program. Figure 5-3 shows the 
corrected program listing. 
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? 

1 

2 
"5 
4 
5 
6 
7 
8 
9 
10 
1 1 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 



LS 
PSIGN42. 




NRGT0 ^TT- 
SEli^ 



AC 3^ 



EAS 



MULTi 



LOOP: 



SAVE 2: 
SAVE 3: 



MAI N/\PRO GRAM 



LD 

JSR 

HALT 

JMP 

ST 

LD 

JSR 

HALT 

JMP 

.WORD 



AC0>EA 
MULT 

.-3 

AC3* SAV3 

AC3*EA 

DIVD 



-4 



0 



SUBROUTINE MULTJpi-V 



ST 
ST 
LI 
LI 
CAI 

SFLG 

SHL 

BOG 

RADD 

ROR 

SHR 

AISZ 



AC 2, SAVE2 
AC 3, SAVE 3 
AC2,0, 
AC3>/l6 
AC0,0 

SELFF 
AC2> 1 
BIT0, .+2 
ACl*AC/^«5. 
AC2> 1 
AC0« 1 
AC3,-1 



vjS^rrMP LOOP 



RCPY 

Rcpy 

LD 
LD 
PFLG 
RTS 
. = . + L 
I 1 



AC0>AC1 
AC2,AC0 
AC 3, SAVE 3 
AC 2, SAVE 2 
SELFF 



AC0=POS JUMP COMDITION 
AC0<=0 JUMP CONDITION 
SELX FLAG 

BIT0=1 JUMP CONDITION 
DEFINE ACCUMULATORS 



; LOAD MULTIPLIER 

; RERUN 

; SAVE AC 3 

; LOAD DIVISOR 

J CALL, ^^upe RoMTif^E: 

; RERUN 



SAVE AC 2 
SAVE AC 3 
CLEAR AC 2 
BIT C0UNT=16 

COMPLIMENT AC0 TO SIMPLIFY 
BRANCHING ON MULTIPLIER BIT0 
INCLUDE LINK IN SHIFTS 
CLEAR LINK 

BRANCH IF AC0 COMPLIMENTED=0 
AC1+AC2 — > AC2 

ROTATE RESULT OF ADD INTO LINK 
SHIFT LINK INTO AC0 
DECR COUNT, SKIP IF ZERO 

MOVE LO ORDER RESULT TO AC 1 
MOVE HI ORDER RESULT TO AC0 
RESTORE AC3 
RESTORE AC2 
CLEAR SELF 



Figure 5-1. Sample Program Needing Correction (Sheet 1 of 2) 
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48 

49 

50 

51 

52 

53 

54 

55 

56 

57 

58 

59 

60 

61 

62 

63 

64 

65 

66 

67 

68 

69 

70 

71 

72 

73 

74 

75 

76 

77 

78 

79 

80 

81 

82 

83 

84 

85 

86 

87 

88 



SUBROUTINE -fi lVD Jlv^Pg 



nnnisiTt .word 



7 



DIVD: ST 

hCPY 

CAI 

RADD 

BOC 

LI 

ST 

SFLG 
LI 
SHL 
SHL 

POOL: ROL 
RCPY 
CAI 
RADD 
BOC 
LI 
SKL 

g JMP 
GOjS: CAI 
RCPY 
LI 
SHL 

SHFTLO: ROL 
ISZ 

JMP 

RCPY 

BOC 

JMP 

RCPY 

< 

OVFLW: LD 

RADD 
JMP 

SAV2: .WORD 
SAV3: .WORD 
H7000: .WORD 



AC2, SAV2 

AC0i AC2 

AC0J 1 

AC3>AC0 

NRGT0,OVFLW 

AC0^-16 

AC0, COUNT 

SELf^P 

AC0>0 

AC0, 1 

ACl, 1 

AC2, 1 

Ae2,AC0. 

AC0* 1* 

AC3> AC0 

NRGT0,GOES 

AC 0*0 

AC0* 1 

SHFTLO 

AC0^ 1 

AC0> AC2 

AC0^-1 

AC0, 1 

ACl^ 1 

COUNT 

POOL 

AC U AC0 

PSIGN>}>}-2 

OVFLW 

AC 2, AC 0 




AC3*H7000 
AC 3* AC 3 
DONE 
0 
0 

X'7000 



SAVE AC 2 

SUBTRACT HI ORDER FROM DIVISOR 

IS HI ORDER 7= DIVISOR 

NO 

SET cour«rT = 16 

SET SELX 
CLEAR LINK 

ROTATE HI ORDER LEFT WITH LINK 



SUBTRACT HI ORDER FROM DIVISOR 

IS HI ORDER >= DIVISOR 

NO 

CLEAR LINK 
YES 

HI ORDER = HI ORDER - DIVISOR 
SET LINK 

ROTATE LO ORDER WITH LINK LEFT 
ARE WE DONE 

NO 
YES 

IS RESULT NEG 
YES* OVERFLOW 

NO MOVE REMAINDER TO AC0* QUOTE 
IN ACl 

SET OVERFLOW 



Figure 5-1. Sample Program Needing Correction (Sheet 2 of 2) 
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? KB TO 1 
-> .TITLE 'MULTIPLY AND 



2 (CR 



DIVIDE ROUTINES* (C 



? MD 4/11 (CR) 
4 PSIGN=2 
ALTERS? PS I GN 



ALTERS? @ 

5 NR^0=11 
ALTERS?NHGT0 



5 NRfiT0 
ALTERS? 6r) 

6 SEl:=2 
ALTERS? SEL 



6 SE^ 
ALTERS? CR) 

7 BlT0=3 
ALTERS?BIT0 



7 Blia 
ALTERS? CR) 

8 AC 0=0 
ALTERS?AC0 



8 ACa 
ALTERS? CH 

9 ACT= 1 
ALTERS? AC 1 



9 ACl 
ALTERS? @ 

10 AC2=2 
ALTERS? AC 2 



10 AC^ 
ALTERS? C^) 

11 AC3=3 
ALTERS? ACS 

1 1 AC^ 
ALTERS? @ 



11 ICR 



1 1 



0 (CR 



1 (CR 



2 (C 



; AC0=POS JUMP CONDITION 

; AC0=POS JUMP CONDITION 

; AC0<=0 JUMP CONDITION 

S AC0<=0 JUMP CONDITION 

; SELX FLAG 

; SELX FLAG 

; BIT0=1 JUMP CONDITION 

S BIT0=1 JUMP CONDITION 

; DEFINE ACCUMULATORS 

; DEFINE ACCUMULATORS 



Figure 5-2. EDIT16 - Implementation of Correction Commands (Sheet 1 of 4) 
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? MS_ 

13 ; 

ALTERS? 

13 1 
ALTERS? 

83 
ALTERS? 

83 
ALTERS? 

? MP 
16 

ALTERS? 
16 

ALTERS? 
21 

ALTERS? 
21 

ALTERS? 

26 S 
ALTERS? j 



'MAIN 



MAIN PROGRAM 
MAIN <CALLING > 

MAIN CALLING PROGRAM 



RCPY 
RCPY 



AC2:,AC0 
AC2>AC0 



i NO MOVE REMAINDER TO AC0, QUOTE 
; NO MOVE REMAINDER TO AC0* QUOTt (CR) 



AC 2, AC 0 



RCPY 



16,21#26*31*34>37*4l (CR 



26 
ALTERS? 
31 

ALTERS? 
31 

ALTERS? 

31 
ALTERS? 

34 
ALTERS? 

34 
ALTERS? 

37 
ALTERS? 

37 
ALTERS? 

41 
ALTERS? 

41 
ALTERS? 



JSR 
JSR 



MULT 
MULT 



; NO MOVE REMAINDER TO AC0> QUOT 



; CALL MULTIPLY ROUTINE fc 



JSR 


MULT 


} CALL MULTIPLY ROUTINE 


JSR 
JSh 


DIVD 
DIVD 


; CALL DIVIDE ROUTINE 


JSR 


DIVD 


; CALL DIVIDE ROUTINE 


SUBROUTINE MULT ^ 
SUBROUTINE MULTIPLY 




SUBROUTINE MULTIPLY 




LI 
LI 


AC3,016 
AC3,t ^ 


; BIT C0UNT=16 


LI 
LI 


AC3* 16 
AC3* 16< > 


; BIT C0UNT=16 


LI 


AC3, 16 


; BIT C0UNT=16 


SFLG 
SFLG 


SEL 

SELFF ^R) 


; INCLUDE LINK IN SHIFTS 


SFLG 


SELFF 


; INCLUDE LINK IN SHIFTS 


RADD 
RADD 


ACUACl ^ 
AC1*AC2 (C^ 


; AC1+AC2 --> AC2 


fiADD 


ACUAC2 


; AC1+AC2 --> AC2 


JSR ^ 
JMP 


^ LOOP 




JMP 


LOOP 





Figure 5-2. EDIT16 - Implementation of Correction Commands (Sheet 2 of 4) 
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? MS 'SE L ' (CRI 
6 SEL 
ALTERS? SELFF (CR) 



6 SEi^F 
ALTERS? (era 

61 
ALTERS? 



61 
ALTERS? 



SFLG 
SFLG 



SEL 
SELFF 



SFLG 



? 
48 



CR] 

MD 48/49,51 (C 



SAVE 2: 
ALTERS? SAVE2: 



48 SAyE2: 
ALTERS? (era 

49 SAUES: 
ALTERS? SAUE3: 



49 SAVES: 
ALTERS? SAVE 3: 



49 SAJZ 
ALTERS? t] 

51 i 

ALTERS?; 



:3: 



WORD 



SELFF 



0 (CR 



SELX FLAG 

SELX FLAG 
SET SELX 

SET SELX 



WORD 

= . + 1 

WORD 



0 



WORD 
WORD 



(CR) 
0 



WORD 



0 



SUBROUTINE DIVD 
SUBROUTINE DIVIDE 



51 

ALTERS? ^CR) 

? LS 53.>94 
53 COUNT; 
VOID RANGE 



SUBROUTINE DIVIDE 



JRD 



7 
91 



LS 91 IC 



? 
72 



• END 

MV 53 TO 91 
MS 'GOS:' ( 



GOS: 
/^TERS?GO<E> 



CA] 



72 GOES: ^^AI 
ALTERS?GOES:t (cr) 

72 GOES: 
ALTERS? (C^ 

4 
80 



CAI 

FS *PSIGN* (c 
PSIGN = 

BOC 



AC0> 1 

AC0> 1 
AC0, 1 

2 

PSIGN>+2 



YES 
I YES 
YES 



AC0=POS JUMP CONDITION 
IS RESULT NEG 



Figure 5-2. EDIT16 - Implementation of Correction Commands (Sheet 3 of 4) 
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MD 80 (CR 



80 
ALTERS? 

80 

ALTERS? (CR) 



BOC PSIG?J*+2 
BOC PSIGN^. + 2 (CR) 



BOC 



? 
57 
81 
84 



FS 'OVFLW ICR 



OVFLW : 
KB TO BA 



BOC 
JMP 
LD 



PSIGN* .+2 



NR6T0, OVFLW 

OVFLW 

AC3,K7000 



IS RESULT NEG 



IS RESULT NEG 



IS HI ORDER 7= DIVISOR 
YES, OVERFLOW 



-> nOMFt PFLfi^ SELFF 
-> RA fCTRL/Q) *** 

-> ' ' 

-> 

-> 



; CLEAR SELX 



J-D_ 



ires^SAva 



RESTORE AC2 



LD 



AC3:. SAV3 



RESTORE AC 3 



-> i ^TRL/Q) *** 



? _LL 
95 



END 



? MP 95 (C R) 
95 .END 

ALTERS? < 



95 

ALTERS? (C 



END 



Figure 5-2. EDIT16 - Implementation of Correction Commands (Sheet 4 of 4) 
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f 


T c; 










1 

1 

o 




.TITLE 


•MULTIPLY AND 


DIVIDE ROUTINES* 


O 


p c T n M 




2 




AC0=POS JUMP CONDITION 


5 


Nrvb i v) 




11 




AC0<=0 JUMP CONDITION 


6 






2 


} 


SELX FLAG 


1 


£3 i 1 k; 




3 


} 


BIT0=1 JUMP CONDITION 


a 
O 


Af CI 




0 


S 


DEFINE ACCUMULATORS 


q 


AC 1 




1 








AC 2 




2 






1 X 






3 






1 P 
















MAIN CALLING PROGRAM 






1 /I 












1 b 




LD 


AC0,EA 


. 


LOAD MULTIPLIER 


I O 




JSR 


MULT 


; 1 


CALL MULTIPLY ROUTINE 


17 




HALT 








1 o 




JMP 


.-3 




RERUN 


1 Q 




ST 


AC3>SAU3 


} 


SAVE AC 3 


o vy 




LD 


AC3>EA 




LOAD DIVISOR 


O 1 




JSR 


DIVD 




CALL DIVIDE ROUTINE 


DO 




HALT 








O 1 
CO 




JMP 


.-4 


} 


RERUN 






.WORD 


0 


















OA 


J 


SUBROUTINE MULTIPLY 






0'7 

/ 


S 










28 


MULTs 


ST 


AC2>SAVE2 




SAVE AC 2 


29 




ST 


AC 3, SAVE 3 


s 


SAVE ACS 


Ok) 




LI 


AC 2,0 




CLEAR AC 2 


o t 
J 1 




LI 


ACS, 16 


» 


BIT C0UNT=16 


OC 




CAI 


AC0>0 


s 


COMPLIMENT AC0 TO SIMPLIFY 


1 "5 
OO 








s 


BRANCHING ON MULTIPLIER BIT0 






SFLG 


SELFF 


s 


INCLUDE LINK IN SHIFTS 






SHL 


AC2, 1 


i 


CLEAR LINK 


oo 




BOC 


BIT0, .+2 


J 


BRANCH IF AC0 COMPLI MENTED=0 


37 




RADD 


AC1>AC2 


i 


AC1+AC2 --> AC2 


38 




ROR 


AC2, 1 


} 


ROTATE RESULT OF ADD INTO LINK 


39 




SHR 


AC0, 1 


i 


SHIFT LINK INTO AC0 


40 




AISZ 


AC3,-1 


} 


DECR COUNT, SKIP IF ZERO 


41 




JMP 


LOOP 






42 




RCPY 


AC0,AC1 


J 


MOVE LO ORDER RESULT TO AC 1 


43 




RCPY 


AC 2, AC 0 




MOVE HI ORDER RESULT TO AC0 


44 




LD 


AC 3, SAVES 


} 


RESTORE ACS 


45 




LD 


AC 2, SAVE 2 


} 


RESTORE AC2 


46 




PFL6 


SELFF 


s 


CLEAR SELF 


47 




RTS 








48 


SAVE 2: 


.WORD 


0 






49 


SAVES: 


.WORD 


0 






50 


> 











Figure 5-3. Corrected Program Listing (Sheet 1 of 2) 
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51 ; SUBROUTINE DIVIDE 

52 i 

53 DIVD: ST AC2, SAV2 

54 RCPy AC0*AC2 

55 CAI AC0* 1 

56 RADD AC3,AC0 

57 BOC NRGT0*OVFLW 

58 LI AC0J-16 

59 ST AC0, COUNT 

60 SFLG SELFF 

61 LI AC0*0 

62 SHL AC0> 1 

63 SHL AC1>1 

64 POOL: ROL AC2> 1 

65 RCPY AC2,AC0 

66 CAI AC0^1 

67 RADD AC3jAC0 

68 BOC [\IRGT0jGOES 

69 LI AC0^0 

70 SHL AC0, 1 

7 1 JMP SHFTLO 

72 GOES: CAI AC0, 1 

73 RCPY AC0,AC2 

74 LI AC0,-1 

75 SHL AC0^ 1 

76 SHFTLO : ROL AC 1*1 

77 ISZ COUNT 

78 JMP POOL 

79 RCPY AC1,AC0 

80 BOC PSIGN*.+2 

81 JMP OVFLlv 

82 RCPY AC2,AC0 
83 

84 DONE: PFLG SELFF 

85 LD AC2,SAVe 

86 LD AC3,SAU3 

87 RTS 

88 OVFLW: LD AC3>H7000 

89 RADD AC3>AC3 
9 0 JMP DONE 

9 1 SAV2: .WORD 0 

92 SAV3: .WORD 0 

93 H7000: .WORD X'7000 

94 COUNT: .WORD 0 
9 5 .END 



; SAVE AC 2 



; SUBTRACT HI ORDER FROM DIVISOR 

; IS HI ORDER 7= DIVISOR 

S NO 

S SET COUNT = 16 

; SET SELX 

; CLEAR LINK 

; ROTATE HI ORDER LEFT WITH LINK 



; SUBTRACT HI ORDER FROM DIVISOR 

; IS HI ORDER >= DIVISOR 

; NO 

; CLEAR LINK 

J YES 

; HI ORDER = HI ORDER - DIVISOR 

; SET LINK 

; ROTATE LO ORDER WITH LINK LEFT 

J ARE WE DONE 

S NO 

S YES 

; IS RESULT NEG 

; YES^ OVERFLOW 

; NO MOVE REMAINDER TO AC0*QUOT 

; IN ACl 

; CLEAR SELX 

; RESTORE AC2 

; RESTORE ACS 



; SET OVERFLOW 



Figure 5-3. Corrected Program Listing (Sheet 2 of 2) 
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Punch the edited text on paper tape. Observe that punched text 
is echoed on the printer. 



? PT 
TUm PUNCH ON 
.TITLE 



•MULTIPLY AND DIVIDE ROUTINES" 



PSIGN = 2 

NHG T 0 = 11 

SELFF = 2 

BIT0 = 3 

ACS = 0 

ACl = 1 

AC2 = 2 

AC3 = 3 

; MAIN CALLING PROGRAM 
S 

LD AC0*EA 



AC0=POS JUMP CONDITION 
AC0<=0 JUMP CONDITION 
SELX FLAG 

BIT0=1 JUMP CONDITION 
DEFINE ACCUMULATORS 



5 LOAD MULTIPLIER 



Figure 5-4. Program Listing on PT Commaad 
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Appendix A 
MP-16 CHARACTER SET 



Table A-1. IMP- 16 Character Set 



Character 


7-Bit 
Hexadecimal 
Nimiber 


Punched 
Card 
Code 


Character 


7-Bit 
Hexadecimal 
Number 


Punched 
Card 
Code 


Ascn 


029 


Ascn 


029 


NUL 




00 


12-0-1-8-9 


I 




21 


11-2-8 


SOH 




01 


12-1-9 






22 


7-8 


STX 




02 


12-2-9 


# 




23 


3-8 


ETX 




03 


12-3-9 


$ 




24 


11-3-8 


EOT 




04 


7-9 


% 




25 


0-4-8 


ENQ 




05 


0-5-8-9 


& 




26 


12 


ACK 




06 


0-6^8-9 


t 




27 


5-8 


BEL 




07 


0-7-8-9 


( 




28 


12-5-8 


BS 




08 


11-6-9 


) 




29 


11-5-8 


HT 




09 


12-5-9 


* 




2A 


11-4-8 


LF 




OA 


0-5-9 


+ 




2B 


12-6-8 


VT 




OB 


12-3-8-9 






2C 


0-3-8 


FF 




OC 


12-4r-8-9 


- 




2D 


11 


CR 




OD 


12-5-8-9 


• 




2E 


12-3-8 


SO 




OE 


12-6-8-9 


/ 




2F 


0-1 


SI 




OF 


12-7-8-9 


0 




30 


0 


DLE 




10 


12-11-1-8-9 


1 




31 


1 


DCl 




11 


11-1-9 


2 




32 


2 


DC2 




12 


11-2-9 


3 




33 


3 


DCS 




13 


11-3-9 


4 




34 


4 


DC4 




14 


4^8-9 


5 




35 


5 


NAK 




15 


5-8-9 


6 




36 


6 


SYN 




16 


2-9 


7 




37 


7 


ETB 




17 


0-6-9 


8 




38 


8 


CAN 




18 


11-8-9 


9 




39 


9 


EM 




19 


11-1-8-9 






3A 


2-8 


SUB 




lA 


7-8-9 


9 




3B 


11-6-8 


ESC 




IB 


0-7-9 


< 




3C 


12-4-8 


FS 




IC 


11-4-8-9 






3D 


6-8 


GS 




ID 


11-5-8-9 


> 




3E 


0-6-8 


RS 




IE 


ll_6-8-9 


? 




3F 


0-7-8 


US 




IF 


11-7-8-9 


@ 




40 


4-8 


SP 




20 


No Punches 










A 




41 


12-1 


a 




61 


12-0-1 


B 




42 


12-2 


b 




62 


12-0-2 


C 




43 


12-3 


c 




63 


12-0-3 


D 




44 


12-4 


d 




64 


12-0-4 


E 




45 


12-5 


e 




65 


12-0-5 


F 




46 


12-6 


f 




66 


12-0-6 


G 




47 


12-7 


g 




67 


12-0-7 


H 




48 


12-8 


h 




68 


12-0-8 


I 




49 


12-9 


i 




69 


12-0-9 


J 




4A 


11-1 


j 




6A 


12-11-1 


K 




4B 


11-2 


k 




6B 


12-11-2 



A-1 



Table A-1, IMP-16 Character Set (Cont) 



Character 


7-Bit 

Hexadec im al 
Number 


Punched 
Card 
Code 


Character 


7-Bit 

Hexadecimal 
Number 


Punched 

Card 
Code 


Ascn 


029 






L 




4C 


11-3 


1 
1 




6C 


12-11-3 


M 




40 


11-4 


m 




6D 


12-11-4 


N 




4E 


11-5 


n 




6E 


12-11-5 


0 




4F 


11-6 


o 




6F 


12-11-6 


P 




50 


11-7 


P 




70 


12-11-7 


Q 




51 


11-8 


<1 




71 


12-11-8 


R 




52 


11-9 






72 


12-11-9 


S 




53 


0-2 


s 




73 


11-0-2 


T 




54 


0-3 


t 




74 


11-0-3 


U 




55 


0-4 






75 


11-0-4 


V 




56 


0-5 


V 




76 


11-0-5 


w 




57 


0-6 


w 




77 


11-0-6 


X 




58 


0-7 


X 




78 


11-0-7 


Y 




59 


0-8 


y 




79 


ll-O-o 


z 




5A 


0-9 


z 




7A 


11-0-9 


[ 




5B 


12-2-8 






7B 


12-0 


\ 

] 


0-8-2 


5C 


0-8-2 






7C 


12-11 


1 


5D 


12-7-8 


ALT 




7D 


11-0 




n 


5E 


11-7-8 


ESC 




7E 


11-0-1 






5F 


0-5-8 


DEL, RUB 




7F 


12-7-9 






60 


8-1 
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Table A-2, Legend for Nonprintable Characters 



Character 


Definition 


Character 


Definition 


■MTTT 


■Mnll 
JNUll 


SO 


Shift out 


SOH 


Start of heading (also start of 


SI 


Shift in 




message) 






STX 




DLE 


Data link escape 


Start of text (also EQA, end 


DCl 




of address) 


Device control 1 








Device control 2 


ETX 


End of text (also EOM, end of 










DCS 


Device control 3 


EOT 


End of transmission (also 


DC4 


Deviep POTrfTnl 4. 




END) 










JNAK. 


Negative acknowledge 


ENQ 


Enquiry (also ENQRY, WRU) 


SYN 


Synchronous idle (SYNC) 




Acknowledge (also RU) 


ETB 


End of transmission block 


BEL 


Rings the bell 


CAN 


Cancel (CANCL) 


BS 


Backspace 


EM 


End of medium 


HT 


Horizontal tab 


SUB 


Substitute 


LF 


Line feed or line space (also 


ESC 


Escape. Prefix 




new line, advances paper to 


FS 


File Separator 




next line, beginning of line) 




VT 


Vertical tab (VTAB) 


GS 


Groip separator 




RS 


Record separator 


FF 


Form feed to top of next page 








(PAGE) 


US 


Unit separator 


CR 


Carriage return 


SP 


Space 
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Appendix B 



INSERTION OF RLM CORRECTIONS 



Corrections may be inserted in RLMs (decks or tapes) by correcting DATA records or adding DATA records 
just before the RLM END record. These records should agree in format with a standard DATA record (see 
IMP-16 Programming and Assembler Manual, appendix A). For simplicity, this section explains how a 
single record may be used to load a single memory location. 

The first word of the corrector record shovild contain X'8005. The second word of the corrector record 

should contain a checksum word X'OOOO so GENLDR does not attempt to checksum the record. The third 

word of the record should contain one of the following values indicating the relocation, if any is to be performed: 

X'OOOO Absolute record (no relocation) 

X'OOOl Base sector relocatable record 

X*0002 Top sector relocatable record 

Word 4 of the record should contain either the absolute initial load address of the record or the proper 
displacement relative to the base- sector or the top- sector origin of the RLM (as indicated by word 3). 

Word 5 of the record should contain one of the following values to indicate the relocation, if any, to be 
performed upon the contents of the data word: 

X'OOOO The data is absolute. 

X'4000 The data references a base-sector relocatable address. 

X'8000 The data references a top-sector relocatable address. 

Word 6 should contain X'OOOO. 

The data word to be inserted should appear in word 7. 
Example: 

In the top sector of an RLM, the following correction is to be inserted: 



Location Value Relocation 

DAA 8109 B 

DAB 5802 A 

DAC A107 T 

DAD 6107 B 

DAE A200 A 

DAF 4A01 A 

DBO 2435 B 



The origin of the ciirrent top sector isDOO. The correctors should contain: 

Columns 



1 5 9 13 17 21 25 



8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


A A 4 


0 


0 


0 


0 


0 


0 


0 


8 10 


9 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


ABO 


0 


0 


0 


0 


0 


0 


0 


5 8 0 


2 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


ACS 


0 


0 


0 


0 


0 


0 


0 


A 1 0 


7 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


AD 4 


0 


0 


0 


0 


0 


0 


0 


6 10 


7 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


A E 0 


0 


0 


0 


0 


0 


0 


0 


A 2 0 


0 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


A F 0 


0 


0 


0 


0 


0 


0 


0 


4 A 0 


1 


8 0 


0 


5 


0 


0 


0 


0 


0 


0 


0 


2 


0 


0 


B 0 4 


0 


0 


0 


0 


0 


0 


0 


2 4 3 


5 
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Appendix C 



FORMAT OF INSTRUCTIONS 



A summary of the instruction types and their assembler language formats is given below for reference. A 
more-detailed breakdown of the instruction codes is shown in the next table; it is suitable for hand-coding 
small programs. 



Instruction Type 
Register to Register 

Register to Memory 
Memory Reference (Class 1) 

Memory Reference (Class 2) 



MACHINE FORMAT 



1 1 1 


1 


1 




1 1 1 1 


1 


op 


sr 


dr 


op 


not used 


op 



Assembler 

Language Format Remarks 



Op sr, dr 



Mill 


1 


1 


op 


r 


disp 


1 1 1 


1 


1 


1 1 1 1 1 M 


op 


r 


xr 


disp 


1 1 1 1 1 


1 


1 1 1 1 1 1 1 


op 


xr 


disp 



Op r, disp 



Op r, disp(xr) Direct 
Op r, @disp(xr) Indirect 



Op disp(xr) Direct 
Op @disp(xr) Indirect 



I/O and Miscellaneous 



1 1 1 1 1 1 1 1 


1 


op 


ctl 



op ctl 





1 1 1 


1 1 1 


i 1 1 1 i 1 1 




Branch 






disp 


Op cc, disp 




op 


cc 



Explanation of Symbols 

OP - Instruction Mnemonic 
Op - Operation Code 
sr - Source Register Vaoue 
dr - Destination Register Value 



disp- Displacement Value 

cc - Condition Code Value 

r - Register Value 

ctl - Control Bits Value 



xr - Index Register Value 



Table C-1. Instruction Set with Bit Patterns 



Mnemonic Base Word Format 

1 = BASE V r V xr V disp 



LD 


8000 










LD Indirect 


9000 










ST 


AOOO 








ADDRESSING 


ST Indirect 


BOOO 


r 


REGISTER 


xr 


TECHNIQUE 


ADD 


COOO 


0000 


0 


0000 


BASE SEGTOR 


SUB 


DOOO 


0400 


1 


0411 


PC RELATIVE 


SKG 


EOOO 


0800 


2 


0200 


INDEXED - AC2 


SKNE 


FOOO 


OCOO 


3 


0300 


INDEXED - AG3 



AND 


6000 


r 


REGISTER 


OR 


6800 


0000 


0 


SKAZ 


7000 


0400 


1 



ISZ 7800 JMP Indirect 2400 

DSZ 7C00 JSR 2800 

JMP 2000 JSR Indirect 2C00 



Word Format 

1 = BASE V cc V disp 

BOG 1000 



Branch on 


INT 


AGO=0 


AGO > 0 


AGO 
ODD 


AGO 
Bit 1=1 


AG?^0 


GPINT 


START 


CC 


0000 


0100 


0200 


0300 


0400 


0500 


0600 


0700 




Branch on 


STFL 


INEN 


GYOV 


AGO<0 


USER^^ 


USER^^ 
^.-"^ 3EL 


USER 


USER 


CC 


0800 


0900 


OAOO 


OBOO 


OCOO 


ODOO 


OEOO 


OFOO 



V , i 



Word Format 

1 = BASE vr vdisp 




AISZ 


4800 






LI 


4C00 


r 


REGISTER 


CAI 


5000 


0000 


0 


PUSH 


4000 


0100 


1 


PULL 


4400 


0200 


2 


XCHRS 


5400 


0300 


3 


ROR/ROL 


5800 


LEFT DISP POSITIVE 




SHR/SHL 


5C00 


RIGHT DISP NEGATIVE 





Word Format 

1 = BASE V sr V dr 



RADD 


3000 


sr 


dr 


REGISTER 


RXCH 


3080 


0000 


0000 


0 


RCPY 


3081 


0400 


0100 


1 


RXOR 


3082 


0800 


0200 


2 


RAND 


3083 


OCOO 


0300 


3 
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Table C-1. Instruction Set with Bit Patterns (Continued) 



Mnemonic 



Base 



Word Format 

1 = BASE vfcvctl 



SFLG 


0800 


fc 


FLAG 


T)T?T 


uoou 


0000 


8 






0100 


9 






0200 


10 






0300 


11 






0400 


12 






0500 


13 






0600 


14 






0700 


15 


HALT 


0000 


RTI 


0100 


PUSHF 


0080 


RTS 


0200 


PULLF 


0280 


JSRI 


0380 



Word Format 
1 = BASEVctl 



RIN 
ROUT 



0400 
0600 



The instruction is formed by the inclusive Or of each field. For example, the instruction RADD 2, 3 is coded 
as X'SCOO. 

For instructions that use the CTL field, only the first 7 bits (bits 0 through 6) are considered. 
Examples of coding follow: 



Example 1 

RADD 2, 3 

BASE = 3000 
sr = 0800 
dr = 0300 
INSTRUCTION = 3C00 

Example 2 

JMP-1 (3) 

BASE = 2000 
xr = 0300 
disp = OOFF 
INSTRUCTION = 23FF 

E xample 3 

SHR 0,1 

BASE = 5C00 
r = 0000 
disp = OOFF 
INSTRUCTION = 5CFF 



Conmients 



Add AC2 to ACS. 



Comments 

Jump to the location specified by the index register 
AC3 modified by the displacement- 1. 



Comments 



Shift the contents of ACO one place to the right. 



Appendix D 



CONVERSION TABLES 



Table D-1, Positive Powers of Two 



2» 



1 
2 
3 
4 
5 

6 
7 
8 
9 
10 

11 
12 
13 
14 
15 

16 
17 
18 
19 
20 

21 
22 
23 
24 
25 

26 
27 
28 
29 
30 

31 
32 
33 
34 
35 

36 
37 
38 
39 
40 

41 
42 
43 
44 
45 

46 
47 

48 
49 
60 



2 

4 

8 

16 

32 

64 

128 

256 

512 

1024 

2048 

4096 

8192 

16384 

32768 

65536 
13107 

26214 
52428 
10485 

20971 
41943 
83886 
16777 
33554 

67108 
13421 
26843 
53687 
10737 

21474 
42949 
85899 
17179 
34359 

68719 

13743 
27487 
54975 
10995 

21990 
43980 
87960 
17592 
35184 

70368 
14073 

28147 
56294 
11258 



52 

04 

08 

216 

432 

864 

7728 

5456 

0912 

41824 

83648 
67296 
34592 
86918 
73836 

47673 

89534 
79069 
58138 
11027 

23255 
46511 
93022 
18604 
37208 

74417 
74883 
49767 
99534 
99906 



4 
8 

6 

72 
44 
88 
776 

552 

104 

208 

4416 

8832 

7664 

55328 

10656 

21312 

84262 



51 

52 
53 
54 
55 

56 
57 
58 
59 
60 

61 
62 
63 
64 
65 

66 
67 
68 
69 
70 

71 
72 
73 
74 
75 

76 
77 
78 
79 
80 

81 
82 
83 
84 
85 

86 
87 
88 
89 
90 

91 
92 
93 
94 
95 

96 
97 
98 
99 
100 

101 



2» 



22517 

45035 
90071 
18014 
36028 

72057 
14411 
28823 
57646 
11529 

23058 
46116 
92233 
18446 
36893 

73786 
14757 
29514 
59029 
11805 

23611 
47223 
94447 
18889 
37778 

75557 
15111 
30223 
60446 
12089 

24178 
48357 
96714 
19342 
38685 

77371 
15474 
30948 
61897 
12379 

24758 
49517 
99035 
19807 
39614 

79228 
15845 
31691 
63382 
12676 



99813 68524 

99627 37049 

99254 74099 

39850 94819 

79701 89639 



59403 
51880 
03761 
07523 
21504 

43009 
86018 
72036 
74407 
48814 

97629 
39525 
79051 
58103 
91620 

83241 

66482 
32965 
46593 
93186 

86372 
57274 
14549 
29098 
25819 

51639 
03278 

06556 
81311 
62622 

25245 
25049 
50098 
00196 
40039 

80078 
60157 
20314 
04062 
08125 

16251 
63250 
20500 
53001 
50600 



79279 
75855 
51711 
03423 
60684 

21369 
42738 
85477 
37095 
74191 

48382 
89676 
79352 
58705 
71741 

43482 

86964 
73929 
14785 
29571 

59143 
51828 
03657 
07314 
61462 

22925 
45851 
91703 
38340 
76681 

53362 
10672 
21345 
42690 
28538 

57076 
14152 
28304 
85660 
71321 

42643 
28528 
57057 
14114 
22822 



8 
6 
2 

84 
68 

36 

872 

744 

488 

6976 

3952 

7904 

5808 

51616 

03232 

06464 
41292 
82585 
65171 
13034 

26068 

52136 
04273 
80854 
61709 

23419 
64683 
29367 
58735 
91747 

83494 
66988 
33976 
66795 
33590 

67181 
53436 
06872 
13744 
02748 

05497 

10995 
21991 
84398 
68796 

37593 
67518 
35037 
70074 
94014 



8 

6 
2 

24 

48 

96 
92 
784 
568 

136 

8272 

6544 

3088 

06176 

12352 
24704 
49408 
29881 
59763 

19526 
23905 
47810 
95621 
99124 

98248 

96496 
92993 
38598 
77197 

54395 
70879 
41758 
83516 
96703 



6 
2 

4 

28 
56 
12 
224 

448 

896 
792 
7584 
5168 

0336 
00672 
01344 
02688 
20537 6 



25353 01200 45645 88029 93406 41075 2 
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Table D-2. Negative Powers of Two 



n 




2-n 








0 


1 


.0 










n 


e; 
. o 








2 


A 

yj 


91^ 
. zo 








3 


0 


.125 








A 
*± 


n 
u 


nfioii 

. VO/CO 








o 


n 
u 


. voizo 








6 


0 


.01562 


5 






7 


n 
u 










a 
o 


u 


onion 








9 


0 


.00195 


3125 






1 n 
iU 


u 


nnnQ7 
. uuuy 1 


DOOZO 






1 1 


n 
u 






o 




12 


0 


.00024 


41406 


25 




1 Q 


u 


nnni o 




1 OK. 






u 


nnnoR 


1 mtii 

lUoOl 






15 


0 


. 00003 


05175 


78125 




ID 


u 


nnnni 


COCQ7 


QnnAo 

oyuo^ 


5 


1 7 


u 


onoon 


7ROQ1 

f Dzyo 






18 


0 


.00000 


38146 


97265 


625 


1 Q 


u 


nnnnn 


1 On7Q 

lyu/ o 


A QAOO 


O 1 O R 

8125 




u 


■ uuuuu 


uyooo 


/4olD 


40625 


21 


0 


. 00000 


04768 


37158 


20312 


99 


u 


. uuuuu 


UZo84 


loo/y 


lUlob 


O'i 
Zo 


U 


■ uuuuu 


m 1 oo 
Ui iyz 


nnoo A 

uyjoy 


55078 


24 


0 


.00000 


00596 


04644 


77539 




U 


nnnnn 
. UUUUU 






38769 


OR 


U 


nnnnn 
. UUUUU 


nni yf n 
UU14y 


ni 1 d 


19384 


27 


0 


. 00000 


00074 


50580 


59692 


Ofi 


U 


. UUUUU 




25290 


29846 


OQ 




r\f*nnn 
. UUUUU 


nnni o 
UUUio 


t5zo45 


14923 


30 


0 


00000 


00009 


31322 


57461 


o 1 


n 

U . 




C\C\(\f\A 

UUUU4 


A C.A^ 1 

DOObl 




QO 


U 


UUUUU 






64365 


33 


0. 


00000 


00001 


16415 


32182 


04 


U . 


UUUUU 


nnnnn 
UUUUU 


58207 


66091 


Q(i 
OD 


U . 


nnnnn 


nnnnn 
UUUUU 


29103 


83045 


36 


0. 


00000 


00000 


14551 


91522 


37 


0. 


00000 


00000 


07275 


95761 


38 


0. 


00000 


00000 


03637 


97880 


39 


0. 


00000 


00000 


01818 


98940 


40 


0. 


00000 


00000 


00909 


49470 


41 


0. 


00000 


00000 


00454 


74735 


42 


0. 


00000 


00000 


00227 


37367 


43 


0. 


00000 


00000 


00113 


68683 


44 


0. 


00000 


00000 


00056 


84341 


45 


0. 


00000 


00000 


00028 


42170 


46 


0. 


00000 


00000 


00014 


21085 


47 


0. 


00000 


00000 


00007 


10542 


48 


0. 


00000 


00000 


00003 


55271 


49 


0. 


00000 


00000 


00001 


77635 


50 


0. 


00000 


00000 


00000 


88817 



5 

25 
125 

0625 
53125 
76562 5 



38281 
19140 
09570 


25 

625 

3125 










54785 
77392 
38696 


15625 
57812 
28906 


5 
25 








69348 
34674 
67337 


14453 
07226 
03613 


125 

5625 

28125 








83668 
41834 
70917 


51806 
25903 
12951 


64062 
32031 
66015 


6 

25 
625 






35458 
17729 

08864 


66475 
28237 
64118 


83007 
91503 
95751 


8125 
90625 

95312 


5 




54432 
77216 
88608 


32059 
16029 
08014 


47875 
73937 
86968 


97656 
98828 
99414 


25 

125 

0625 




94304 
47152 
73576 


04007 
02003 
01001 


43484 
71742 
85871 


49707 
24853 
12426 


03125 
51562 
75781 


5 

25 


36788 
68394 
84197 


00500 
00250 
00125 


92935 
46467 
23233 


56213 
78106 
89053 


37890 
68945 
34472 


625 

3125 

65625 
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Table D-3. Hexadecimal and Decimal Integer Conversion Table 





8 


7 


6 


5 


4 


3 


2 




1 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


1 


268.435.456 


1 


16.777.216 


1 


1,048.576 


1 


65.536 


1 


4.096 


1 


256 


1 


16 


1 


1 


2 


536.870.912 


2 


33.554.432 


2 


2.097.152 


2 


131.072 


2 


8.192 


2 


512 


2 


32 


2 


2 


3 


805.306.368 


3 


50.331.648 


3 


3.145.728 


3 


196.608 


3 


12.288" 


3 


768 


3 


48 


3 


3 


4 


1.073.741.824 


4 


67.108.864 


4 


4.194.304 


4 


262.144 


4 


16.384 


4 


1.024 


4 


64 


4 


4 


5 


1.342,177.280 


5 


83.886.080 


5 


5.242.880 


5 


327,680 


5 


20.480 


5 


1.280 


S 


80 


5 


5 


6 


1. 610.61 2.736 


6 


100.663.296 


6 


6.291.456 


6 


393,216 


6 


24.576 


6 


1.536 


6 


96 


6 


6 


7 


1,879.048.192 


7 


117.440.512 


7 


7.340.032 


7 


458.752 


7 


28.672 


7 


1.792 


7 


112 


7 


7 


8 


2.147.483.648 


8 


134.217.728 


8 


8.388.608 


8 


524.288 


8 


32.768 


8 


2.048 


8 


128 


8 


8 


9 


2,415,919,104 


9 


150.994.944 


9 


9.437.184 


9 


589,824 


9 


36.864 


9 


2.304 


9 


144 


9 


9 


A 


2.684.354.560 


A 


167.772.160 


A 


10.485.760 


A 


655,360 


A 


40.960 


A 


2.560 


A 


160 


A 


10 


B 


2,952,790,016 


B 


184.549,376 


B 


11.534.336 


B 


720,896 


B 


45.056 


B 


2.816 


B 


176 


B 


1 1 


C 


3,221.225,472 


C 


201,326,592 


C 


12.582.912 


C 


786.432 


C 


49.152 


C 


3.072 


C 


192 


C 


12 


D 


3,489.660,928 


D 


218.103.808 


D 


13.631.488 


D 


851.968 


D 


53.248 


D 


3.328 


D 


208 


D 


13 


E 


3,758.096.384 


E 


234.881.024 


E 


14.680.064 


E 


917.504 


E 


57.344 


E 


3.584 


E 


224 


E 


14 


F 


4,026,531.840 


F 


251,658.240 


F 


15.728.640 


F 


983.040 


F 


61.440 


F 


3,840 


F 


240 


F 


15 




8 


7 


6 


5 


4 


3 


2 


1 



TO CONVERT HEXADECIMAL TO DECIMAL 

\. Locate the column of decimal numbers 
corresponding to the left-most digit or 
letter of the hexadecimal: select from this 
column and record the number that cor- 
responds to the position of the hexa- 
decinial digit or letter. 

2. Repeat step 1 for the next (second from 
the left) position. 

3. Repeat step 1 for the units (third from 
the left) position. 

4. Add the numbers selected from the table 
to form the decimal number. 

To convert integer numbers greater than 
the capacity of table, use the techniques 

below: 

HEXADECIMAL TO DECIMAL 

Successive cumulative multiplication 
from left to right, adding units position. 

Example: D34i6 = 3380 lo 



D 


13 




xl6 




208 


3 


= -1-3 




211 




X 16 




3376 


4 


= +4 




3380 



EXAMPLE 


Conversion of 


Hexadecimal 




Value 


D34 


1. D 


3328 


2. 3 


48 


3. 4 


4 


4. Decimal 


3380 



TO CONVERT DECIMAL TO HEXADECIMAL 

1. (a) Select from the table the highest deci- 
mal number that is equal to or less than 
the number to be converted. 

(b) Record the hexadecimal of the col- 
umn containing the selected number. 

(c) Subtract the selected decimal from 
the number to be converted. 

2. Using the remainder from step 1(c) repeat 
all of step 1 to develop the second posi- 
tion of the hexadecimal (and a re- 
mainder). 

3. Using the remainder from step 2 repeat 
all of step 1 to develop the units posi- 
tion of the hexadecimal. 

4. Combine terms to form the hexadecimal 
number. 

DECIMAL TO HEXADECIMAL 



Divide and collect the 
reverse order. 

Example: 3380io = Xi6 

16 I 3380\ remainder 

16 I 211 ^ M 

16 I 13 ^3 

3380 10 = D34,6 



remainder in 



EXAMPLE 


Conversion 


of 


Decimal 




Value 


3380 


1. D 


-3328 




52 


2. 3 


-48 




4 


3. 4 


-4 


4. Hexa- 




decimal 


D34 
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Table D-4. Hexadecimal and Decimal Fraction Conversion Table 



1 


2 


3 


4 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal Equivalent 


.0 


.0000 


.00 


.0000 


0000 


.000 


.0000 


0000 


0000 


.0000 


.0000 


0000 


0000 


0000 


.1 


.0625 


.01 


.0039 


0625 


.001 


.0002 


4414 


0625 


.0001 


.0000 


1525 


8789 


0625 


.2 


.1250 


.02 


.0078 


1250 


.002 


.0004 


8828 


1250 


.0002 


.0000 


3051 


7578 


1250 


.3 


.1875 


.03 


.0117 


1875 


.003 


.0007 


3242 


1875 


.0003 


.0000 


4577 


6367 


1875 


.4 


.2500 


.04 


.0156 


2500 


.004 


.0009 


7656 


2500 


.0004 


.0000 


6103 


5156 


2500 


.5 


.3125 


.05 


.0195 


3125 


.005 


.0012 


2070 


3125 


.0005 


.0000 


7629 


3945 


3125 


.6 


.3750 


.06 


.0234 


3750 


.006 


.0014 


6484 


3750 


.0006 


.0000 


9155 


2734 


3750 


.7 


.4375 


.07 


.0273 


4375 


.007 


.0017 


0898 


4375 


.0007 


.0001 


0681 


1523 


4375 


.8 


.5000 


.08 


.0312 


5000 


.008 


.0019 


5312 


5000 


.0008 


.0001 


2207 


0312 


5000 


.9 


.5625 


.09 


.0351 


5625 


.009 


.0021 


9726 


5625 


.0009 


.0001 


3732 


9101 


5625 


.A 


.6250 


.OA 


.0390 


6250 


.OOA 


.0024 


4140 


6250 


.OOOA 


.0001 


5258 


7890 


6250 


B 


.6875 


.OB 


.0429 


6875 


.00 B 


.0026 


8554 


6875 


OOOB 


.0001 


6784 


6679 


6875 


C 


.7500 


.OC 


.0468 


7500 


OOC 


.0029 


2968 


7500 


.OOOC 


.0001 


8310 


5468 


7500 


D 


.8125 


.OD 


.0507 


8125 


.OOD 


.0031 


7382 


8125 


OOOD 


.0001 


9836 


4257 


8125 


E 


.8750 


.OE 


.0546 


8750 


OOE 


.0034 


1796 


8750 


.OOOE 


.0002 


1362 


3046 


8750 


F 


.9375 


.OF 


.0585 


9375 


.OOF 


.0036 


6210 


9375 


OOOF 


.0002 


2888 


1835 


9375 


1 


2 


3 


4 



TO CONVERT .ABC HEXADECIMAL TO DECIMAL 

Find .A in position 1 .6250 
Find .OB in position 2 .0429. 6875 
Find .OOC in position 3 .0029 2968 7500 
ABC Hex is equal to .6708 9843 7500 



Table D-5. Integer Conversion Table 

POWERS OF 16 TABLE 

Example: 268,435,456|o = (2.68435456 x IO*)io = 1000 0000,6 = (10'),6 







16" 








n 












1 


0 














16 


1 














256 


2 












4 


096 


3 












65 


536 


4 










1 


048 


576 


5 










16 


777 


216 


6 










268 


435 


456 


7 








4 


294 


967 


296 


8 








68 


719 


476 


736 


9 






I 


099 


511 


627 


776 


10 = 


A 




17 


592 


186 


044 


416 


11 = 


B 




281 


474 


976 


710 


656 


12 = 


C 


4 


503 


599 


627 


370 


496 


13 = 


D 


72 


057 


594 


037 


927 


936 


14 = 


E 


1 152 


92! 


504 


606 


846 


916 


^5.= 


F 



' V 

Decimal Values 
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NEGATIVE HEXADECIMAL NTMBERS 

The IMP-16 maintains negative numbers in twos-complement form. To convert a ntmber in hexadecimal 
notation to its twos-complement equivalent, subtract the number from 2^ caressed in hexadecimal form. 
The number "n" is the number of binary bits in the computer word. For example, if the computer uses 
a 16-bit word, the number "n" is equal to 16. Thus, the negative of 1245^6 is derived as follows: 



Note that a hexadecimal number wiU be negative in the IMP-16 computer if the left most digit is 8, 9, A, B, 
C, D, E, or F. Thus, FACE is equal to 1111 1010 1100 1110; the twos complement is: 



10000 
-1245 
EDBB 



1 0000 0000 0000 0000 
- 0001 0010 0100 0101 



1110 1101 1011 1011 



1 0000 

FACE 
532 



1 0000 0000 0000 0000 

nil 1010 1100 1110 



0000 0101 0011 0010 
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Appendix E 
EDITie SYMBOL MEANINGS AND USAGE 

The following symbols and their meanings are used in tiie examples associated with chapter 5, EDITie, 

• All imderlined, upper-case characters represent Teletype keyboard, user entries. 

• Encircled characters or combinations of characters represent nonprinting, or control characters. 
H underlined, they represent user initiated input; if not underlined, they represent computer 
generated characters, 

• CTKL/X represents a user input where the Teletype CONTROL key is pressed and held, 
while the X key is pressed. Similarly, any key (for a printing character) may be pressed in 
combination with the CONTROL key. The symbol then is CTRL/(key). 

Table E-1 lists the symbols used in this text for the EDIT16 program. 



Table E-1. EDITie Symbols 


Sjnnbol 


Meaning 


\ 


Back arrow. Indicates Teletyi)e keyboard error correction of previous 
character, or midtiples of characters (depending on number of arrows 
used. 

Echo for CNTL/X input, indicates position of character to be deleted. 




Prompt, from EDIT16, shows readiness to accept a new line. 




Prompt, from EDm6, shows readiness to accept command. 


@ 


Carriage Return 


@ 


Line Feed 


(ctrl/a) 


Start of character insert (^oration. 


(ctrl/d) 


Truncates the current line. 


(ctrl/q) 


Aborts the current line modification operation. 


(ctrl/x) 


Deletes the character in tiie corresponding position in the previous line. 


(ctrl/z) 


Carriage Tab feature 
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CHANGE NOTICE NUMBER 1 



PubUcation No. 4200025B 
Order No. IMP-16S/025YB 



IMP-16 UtULties 
Reference Manual 



This change is effective immediately for the following programs: 



PROMP 
DEBUG 
EDIT16 
STTYIO 



4300308B 
4300112C 
4300332B 
4300158C 



Page ii. PREFACE. Add to paragraph 1: 

To facilitate use of these programs and to minimize loading time, DEBUG, PROMP, and EDIT16 are 
assembled in absolute format so that they may be loaded into the user's environment using either 
GENLDR or one of the available absolute loaders. 

Page 1-1. Section 1. 2. Insert before paragraph 1: 

DEBUG is assembled relative to location X'lO in Base Page and location X'210 in Top Sector. This 
means that DEBUG may be loaded into the user's eavironment either by an absolute loader (see 
sections 2. 2 and 2. 3 of tills manual) or by GENLDR (see section 2. 5 of this manual). If loaded by an 
absolute loader, DEBUG will occupy Base Page locations X'lO through X'lO, and Top Sector locations 
X'210 through X'654. 

If DEBUG is loaded by GENLDR, DEBUG will appear to occupy Base Page locatioas 0 through X'F 
and Top Sector locations 0 through X'20F as well as its normal memory areas. If the GENLDR 
commands 



are executed prior to loading DEBUG, the program will occupy the same memory locations as if it 
were loaded absolutely. - If it is desired to use the X'lO locations preceding the DEBUG Base Page 
or the X'210 locations preceding the DEBUG Top Sector, appropriate !OTS and JOBS commands 
should be executed. As an example, DEBUG Top Sector might be located at X'lOOO by using a 

!OTS DFO (X'lOOO - X'210) 

command. In essence, the specified Top Sector origin must precede the desired Top Sector origin 
by X'210 locations. 

Page 1-1. Section 1.2. Existing paragraph 1, delete the first sentence, reading: 

DEBUG is a relocatable . . . other relocatable program. 

P^e 1-1. Section 1. 2. 1, change to read: 

Hie following memory is needed to execute DEBUG: 

Top Sector: X'445 or 1093 words. 

Base Page: 7 words. 



!OBS0 
lOTSO 
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Page 3-2. Section 3. 2, 3, sentence 1. Change "STTYIO (zero)" to read "STTYIO (letter)". 
Page 3-2. Section 3.3. Change to read: 

STTYIO is assembled as a relocatable load module and must be loaded by GENLDR, (See section 2. 5 
of this manual. ) 

Page 4-1. Section 4. 1, replace last sentence by: 

PROMP output tapes may be used to program either MM5203 2K PROMs in a 256-by-8 structure or 
MM5204 4K PROMs in a 512-by-8 structure. If MM5203 PROMs are used, two PROMs are required 
to make up a 256-word by 16-bit memory page. 

Page 4-1. Section 4. 1, add paragraph 2: 

If the BC tape option is selected, PROMP will calculate a 16-bit checksum of the tape and punch it at 
the end of the tape as foxir hexadecimal characters in ANSI code. 

Page 4-1. Section 4. 2. 1. Change to read: 

PROMP is assembled relative to location X'250 in Top Sector. This means that PROMP may be 
loaded into the user's environment either by an absolute loader (see sections 2. 2 and 2. 3 of this 
manual) or by GENIDR (see section 2. 5 of this manual). If loaded by an absolute loader, PROMP 
will occupy memory locations X'250 through X'9CC. 

If PROMP is loaded by GENLDR, it will appear to occupy Top Sector locations 0 through X'24F as 
well as its normal memory area. If the GENLDR command 

!OTS 0 

is executed prior to loading PROMP, the program will occupy the same memory locations as if it 
were loaded absolutely. If the user desires to use the X'250 locations preceding the PROMP Top 
Sector, an appropriate !OTS command should be executed. For example, PROMP might be loaded 
at X'lOOO by using a 

!OTS DBO (X'lOOO - X'250) 

command. In essence, the specified Top Sector origin must precede the desired Top Sector origin 
by X'250 locations. 

Page 4-1. Section 4. 2. 2. Change to read: 

PROMP requires 780-|^g words of top sector memory. 

Page 4-1 through 4-3, section 4. 2, 3, replace with the following: 

4.2.3 Program Messages 

To guide the user in the use of PROMP, query messages are typed. There are four general messages 
correspaiding to the four possible program states. Initially, PROMP types: 

NSC IMP-16 FIRMWARE PAPER TAPE GENERATOR 
OUTPUT TYPE: 
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The user must then respond with one of the following codes: 

PN - For PN format PROM tape. 

BC - For binary (complemoited) format PROM tape. 

OM - For card RLM to tape RLM conversion. 

All responses must be terminated by a carriage return. For the OM option, PROMP types the following 
message and goes into an output state: 

MAKE CARD READER READY 

TURN PUNCH ON 

HIT ANY KEY TO START 

At this point, RLM records are converted from card to paper tape. After processing the END record, 
PROMP goes into a wait state. The user may now turn off the Teletype punch. Typing any key returns 
the PROMP program to the initial state. 

In either PN or BC options, PROMP goes into an iapat state. The following message is typed: 

INPUT DEVICE: 

The user may respond with one of the following codes: 

CR - Card Reader 
PT - Teletype 
ME - Memory 

ME Option . If this device is selected, PROMP then types: 
SPECIFY MEMORY ~ 

The user must then type the message rai^e, where the user program is located. A range is designated 
by the start address and the last address, delimited by a colon (:); the range must be in blocks of 25Siq 
or 512io words. 

Example: 

SPECIFY MEMORY — FFOO:FFFF 

CR Option . PROMP types the following message: 

MAKE CARD READER READY 
TO LOAD LM 

The card reader must be turned on at this point. The LM will be immediately read into memory. 

PT Option . If this device is selected, PROMP types the message: 

MAKE TAPE READER READY 
TO LOAD LM 

The LM will be loaded immediately into memory. After the loading process, when the END record is 
recognized, PROMP types: 

TURN READER OFF 

The user must turn off the reader and press any key to initiate the output process. 
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Mode and Byte Requests. PROMP may be used for punching programming tapes for either the MM5203 
2K PROM or the MM5204 4K PROM. After loading the LM, PROMP will query the user as to which 
PROM is being used. 

SET MODE: 

TAPE FOR MM5203 2K PROM - TYPE 2 
TAPE FOR MM5204 4K PROM - TYPE 4 
TYPE: 

The MM5203 PROM is structured in a 256-word by 8-bit format, while the MM5204 PROM is structured 
in a 512-word by 8-bit format. PROMP allows the user to program PROMs for either 256- or 512-word 
memory regions using the MM5203, and for a 512-word region using the MM5204. In order to do this, 
the user must respond to the query 

BYTE: 

with one or more of the options, L, R, LL, LR, HL, and HR according to the following tables: 



MM5203 2K PROM 



Address 


Range 


BITS 


15-8 


7-0 


N 

N+256 


N+255 
N+511 


LL 
HL 


LR 
HR 


MM5204 4K PROM 


Address 


Range 


BITS 


15-8 


7-0 


N 


N+511 


L 


R 



If more than one option is desired, each entry may be separated either by commas or by spaces. For 
a particular PROM, if all options are desired, the user may respond with a carriage return. After the 
option is typed, PROMP comes back with the message: 

TURN PUNCH ON 

HIT ANY KEY TO START 

After the output process, PROMP goes into its last state, the wait state. This wait state is provided 
so that the user can turn off the punch before any message is typed by PROMP. To return to the initial 
state, the user must press any key on the keyboard. 

Typing CTRL/D when PROMP is waiting for a response transfers the user to the initial state. Leaders/ 
trailers are punched automatically. If PN is chosen as an output type code, pressing any key during the 
output process causes an interrupt of the current output option and initiates processing of the next output 
option. Under certain conditions, the key must be struck several times in order to cause an interrupt. 
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Page 4-4. Section 4.4, following table 4-1, add: 

Figure 4-1 illustrates the PROMP operational sequence in flowchart form. 
Add figure 4-1 (which is on next page, 4-4A). 



Page 5-7. Section 5. 5.1. Insert before paragraph 1: 

EDIT16 is assembled relative to location 0 in Base Page and location X'120 in Top Sector. This 
means that EDIT16 may be loaded either by an absolute loader (see sections 2. 2 and 2. 3 of this 
manual) or by GENLDR (see section 2. 5 of this manual). If loaded by an absolute loader, EDIT16 
will occupy the Base Page locations 0 through X'78, and Top Sector locations X'120 through X?7FB. 

J£ EDIT16 is loaded by GENLDR, it will appear to occupy Top Sector locations 0 through X'llF as 
well as its normal memory areas. If the GENLDB commands, 

!OBS 0 
!OTS0 

are executed prior to loading EDIT16, the program will occupy the same memory locations as if it 
were loaded absolutely. If it is desired to use the X'120 locations preceding the EDIT16 Top Sector, 
the appropriate !OTS command should be executed. As an example, EDIT16 Top Sector might be 
located at X'lOOO by using a 

!OTS EEO (X'lOOO - X'120) 

command. In essence, the specified top sector origin must precede the desired top sector origin 
by X'120 locations. 



Page 5-7. Section 5. 5. 1. Existing paragraph 1: delete the first sentence, reading: 

"The EDm6 program . . . starts automatically". 

Change the second sentence to read: 

Once loaded, the following messages are typed: 

NSC EDIT 16 REV X 
MEMORY: 

Effective immediately, all references to "Relocatable Load Module" (RLM) shall be changed to "Load 
Module" (LM). Load Modules may be either relocatable or absolute, depending on context or usage. 
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OM 



MAKE CARD 


CR_^ 


READER READY 


TO LOAD LM 





INPUT \mE 
DEVICE 






MAKE CARD 




READER READY, 




TURN PUNCH ON, 




HIT ANY KEY 




TO START 


1 

PROMP READS LM 


FROM CR AND 


PUNCHES TAPE. 


J, ME 


SPECIFY 




MEMORY 



PROMP 
LOADS LM 



MAKE TAPE 
READER READY 
TO LOAD LM 



USER SPECIFIES 
MEMORY RANGE 



PROMP 
LOADS LM 



TURN 
READER OFF 




CHANGE NOTICE NUMBER 2 
November 15, 1974 

IMP -16 Utilities 
Reference Manual 



This change is effective immediately. 

Page 5-1. Section 4. 2. Add to first paragraph: 

"Those commands that require text mode processing are KB, RT, RC, MB, and MS." 

Page 5-2. In first line, replace "Specifies" with "Separates". 

Page 5-2. Section 5. 3. 3. Change last sentence of paragraph to read: 

"The edit buffer is located in the remainder of memory above the EDITie code so its size is dependent on the 
machine memory space. " 

Page 5-3. Section 5.4. 2. After the first pars^aph, change to read as follows: 

Example: 

? RT 2 6^ Apend two lines to the edit buffer. This message 

TUTRN READER OFF NOW is typed after the second line is read. 

"If the edit buffer becomes full when entering lines using KB, RT, and RC commands, the message 

BUFFER FULL 

is typed and EDITie goes into command mode. Again, an incomplete line is not entered to the buffer. " 

"If a BUFFER FULL message is typed, the user may recover by punching a few lines from the beginning of the 
buffer onto paper tape and, then, deleting those lines from the buffer. " 

Page 5-4. Section 5.4. 8. Add to first para^aph: 

t 

"EDme will type the line to be modified and, then, will prompt for modifications by typing ALTERS?. " 
Page 5-4. Section 5.4. 8. Add after first paragraph: 

"Typing @ as the first character after ALTERS? causes EDITie to terminate the modification and to 
prompt for a command. " 

Page 5-5. Add after sentence following second example of Section 5. 4. 8: 

"If CTRL/Z is followed by another control character, EDIT16 will reprompt for ALTERS ?. " 

Page 5-5. After the third example of Section 5.4. 8 between ALTERS? and "Typing a CRTL/Q aborts the 
current line modification.", add the following: 

"Attempting to add a line feed (LF) character will cause loss of a character from the original text. " 

"EDITie limits the maximum line length to 65 characters. If the user attempts to exceed this limit by inserting 
characters, the insertion will be aborted. The user, then, may delete characters from the end of the line, re- 
perform the insertion, and then add the deleted characters to the next line or insert them foUowii^ the current 
line. " 



Publication Number 4200025B 
Order Number IMP-ieS/025YB 
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Page 5-6. Section 5.4. 9. Immediately preceding 5.4. 10 (that is, as the last of Section 5.4. 9), add the 
following: 

"The user will be prompted with ALTERS? for each line containing the specified string. If alteration of a 
particular line is not necessary, he may respond with a @ immediately following the prompt. " 

"If it is desired to terminate modifications, the user may type CCTRL/q") . " 

Page 5-7. Section 5.4. 15. Add new paragr^h: 

"When entering data via EDITie, CCTRL/l ) should be used to skip to the next tab setting. " 
Page 5-8. Add the following as Section 5.5.3: 
"5. 5. 3 Restarting EDIT16 

EDIT 16 may be restarted by pressing INITIALIZE, setting the PC to the value contained in the data item 
RINiri (see listing), and pressing RUN. " 

Page C-1. FORMAT OF INSTRUCTIONS delete the words "to Memory" for second format, now "Register 
to Memory." 
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CHANGE NOTICE NUMBER 3 
(28 February 1975) 



Publication No. 4200025B IMP-16 Utilities 

Order No. IMP-16S/025YB Reference Manual 



This change is effective immediately for the following program: 

PROMP 4300308C 

Only changes incurred by Change Notice Number 1 are affected by this change notice. Thus, references to page 
numbers and sections apply to Change Notice Number 1. Changes or additions are underscored. 

NOTE 

Information in Change Notice Number 1 pertaining to 
other programs listed therein is still in effect. 

Page 2 — affecting manual Section 4.1, addition of paragraph 2.3 should state: 

If the BC tape option is selected, PROMP will calculate a 32 -bit checksum of the tape and punch it at 
the end of the tape as eight hexadecimal characters in ANSI code. 

Page 3 — affecting replacement of Section 4. 2. 3, Program Messages, of the manual, add second sentence so 
fourth paragraph states: 

At this point, RLM records are converted from card to paper tape. GENLDR commands such as 
!RLM are ignored . After processing the END record, PROMP goes into a wait state. The user may 
now turn off the Teletype punch. Typing any key returns the PROMP program to the initial state. 
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CHANGE NOTICE NUMBER 4 
(1 July 1975) 



Publication No. 4200025B 
Order No. IMP-16S/025YB 



IMP-16 Utilities 
Reference Manual 



This change notice affects the IMP-16 General Loader Program, GENLDR. 

Replace the existing section 2. 5 (through 2. 5. 19) of the subject manual with the attached section 2. 5. 



2.5 GENLDR (IMP-16 GENERAL LOADER) 

GENLDR is a stand-alone IMP-16 program that reads one or more load modules (LMs) produced by the IMP-16 
assembler, performs relocation, resolves external linkages, and loads the LMs into main memory for execu- 
tion. The load modules produced by the assembler may be read from either cards or paper tape. 

The paragraphs that follow describe the commands to control GENLDR and the input sequences required to load 
an executable program into the IMP-16 main memory. Error messages and diagnostic output of GENLDR are 
also described. 

NOTE 

The prefix X' designates that the number that follows is hexadecimal. 



2.5.1 Usage 

GENLDR is a relocatable stand-alone IMP-16 program that may be loaded into memory by one of two absolute 
loaders: (1) ABSCR allows GENLDR to be input from cards and (2) ABSPT, from paper tape. Once loaded, 
GENLDR can accept input from either cards or paper tape; although, initially, it accepts input from the device 
from which it was loaded. 



GENLDR occupies approximately 1568 words of memory and is typically loaded into upper memory. Programs 
cannot be loaded by GENLDR into memory that it occupies or uses for the symbol table it generates. However, 
GENLDR allows the user full use of base page. The memory layout is described in figure 2-3. 

GENLDR is assembled relocatable and occupies the (relative) addresses X'09E0 through X'OFFF. It is recom- 
mended that it be loaded into the highest locations of memory available in the system, for ease of use and to 
enable GENLDR to remain resident while other programs are running. To load it into the top of an 8 K memory, 
for example, first load it with the absolute loader, and then use GENLDR to relocate itself with the !OTS 1000 
command. GENLDR would then reside in the memory locations X'19E0 through X'lFFF. 

GENLDR is self-initializing; it may be entered at its entry point at any time. The entry point is X'0A5F in a 4K 
system. The value of ACS is used to determine the initial load device: if ACS = 0, the device is the Teletype: 
otherwise, it is the card reader. If GENLDR is entered after pressing initialize, the device will be the Teletype. 

The IMP-16 assembler allows the user to allocate portions of his program in three ways: 

• At an absolute memory location 

• Relative to the origin of the base sector 

• Relative to the origin of the top sector 
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SYMBOL TABLE 
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TOP SECTORg 




TOP SECTOR^ 


INDIRECT POINTERS 1 
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BASE SECTOR J 





HIGH MEMORY 
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FF 



16 



00 
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Figure 2-3, Memory Map 
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Typically, absolute allocation is employed to assign locations dependent upon equipment (for example, interrupt 
entrance address) or to communicate with special-purpose routines. The base sector must be located such that 
it is contained within the first 256 (X'lOO) locations of memory and typically contains data and pointers necessary 
lor inter-LM communication. The top sector may reside anywhere in memory (subject to the limitations men- 
tioned above) and normally contains the main portion of the LM. Care must be exercised to ensure that an ab- 
solute sector does not overlay a previously loaded base sector or top sector. (See !OBS and !OTS commands in 
the following paragraphs.) 

Two other limitations are imposed upon the base sector by the IMP-16 computer architecture and the method for 
resolving external linkages. First, any base sector variable that is referenced by an indexed instruction must 
be allocated to one of the first X'7F locations of memory. Second, in resolving certain external linkages, 
GENLDR may force an indirect reference to a global variable through a pointer in the memory area X'FF and 
downward. 

The area of IMP-16L memory between locations X'lOO and X'llF is used by the control panel service routine and 
may not be used by the user. Above address X'FF, loading is limited only within the area occupied by GENLDR 
and the S3rmbol table it generates. In the IMP-16P, GENLDR allows the locations used for its IMP-16L Teletype 
input/output to be overwritten, so the effective starting location of GENLDR is X'OASl. The GENLDR area may 
be used by the loaded program, after it receives control from GENLDR; but it is recommended that GENLDR be 
left in memory so that it may be reused without necessitating reloading. 

As an entry point, GENLDR selects the last nonzero value specified for the set of LMs loaded. The entry point 
for any particular LM, if specified, appears in the end record of that LM. If the user desires, he may override 
the entry point selected by GENLDR by specifying the desired entry point in the !GO command (paragraph 
2. 5. 4. 13). If neither of these methods is chosen, GENLDR prints an "ENT?" error message and prompts for 
a new command. 



2. 5. 2 GENLDR Input 

GENLDR is controlled by commands and by the load module data. GENLDR reads commands and LMs from 
either cards or paper tape, and commands are available to switch between input devices. (See ICR and !TTY, 
paragraphs 2. 5. 4. 6 and 2. 5. 4. 7. ) GENLDR does not recognize any distinction between the Teletype paper tape 
reader and the Teletype keyboard; therefore, the user may type in his commands at the keyboard and input the 
LM from paper tape. Commands entered on paper tape, the keyboard, or from the card reader are echoed 
back to the Teletype printer: the LM itself is not echoed. 

Commands entered on punched cards must contain an exclamation point (!) in column 1. When the command is 
entered from the Teletype, GENLDR types the exclamation point to prompt for a command. Any additional 
exclamation point typed from the keyboard is ignored. If it is necessary to return to command mode while in 
the middle of an LM, an exclamation point may be typed on the keyboard (between LM records only), and GENLDR 
then prompts for a command. Any command may be given at this point, but only commands not affecting loading 
may be used if the LM is to be continued. 

Input lines on the Teletype are terminated by a carriage return. A maximum of 72 characters is allowed in one 
Teletype input record; excess characters are not allowed. Only the characters from X'20 through X'5F are 
allowed in Teletype commands; any other character except carriage return causes the command to be aborted 
and a new prompt issued. The Null (X'OO) and Rubout (X'7F) characters are, however, ignored. 
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2.5.3 GENLDR Output 



GENLDR prints information descriptive of the loading process. The title information, absolute sector limits, 
base sector limits, top sector limits, and entry point address of each LM are printed on the Teletype. Unless 
! NLM is in effect, GENLDR types the following information for each LM: 

MNEMONIC STRING 
AAAA BBBB 

AS=XXXX:XXXX BS - XXXX:XXXX TS = XXXXrXXXX ENT=XXXX 



Where: 



MNEMONIC 
STRING 
AAAA BBBB 

AS - XXXXrXXXX 
BS = XXXXiXXXX 
TS = XXXX:XXXX 
ENT =XXXX 



is the name of the LM from the title record. 

is the qualifying string from the title record. 

are the LM source and object checksums, respectively. 

specifies the low and high addresses of the absolute sector (if any). 

specifies the base sector origin and last base sector address (if any). 

specifies the top sector origin and last top sector address (if any). 

is the entry address from the end record (if any). 



All numbers (XXXX) are printed in hexadecimal notation. 

If !SY or !ER is executed, GENLDR prints symbols as follows: 



SYMBOL XXXX F 



Where: 



• SYMBOL is the symbol name. 

• XXXX is the hexadecimal address of the symbol. 

• F is one of the following: 

M — multiply-defined symbol 

U — undefined symbol 

blank — defined symbol 
The address printed for an undefined symbol is the last address where the symbol is 
referenced (in a . WORD) or the base page pointer location. 

If the IRA command is given to list the range of loaded addresses, or upon execution of a !GO command, the 
following information is typed: 

AS = XXXX-JCXXX BS = XXXX:XXXX TS - XXXX:XXXX PTR = XXXX:XXXX ENT = XXXX 



Where the first hexadecimal value is the lowest address actually loaded in the specified sector, and the second 
hexadecimal value is the highest address actually loaded. PTR = XXXX:XXXX gives the limits of the loader- 
generated indirect pointers. These ranges are global; that is, they cover all programs loaded and are not 
affected by the use of the ! LM or !NLM commands. 



2. 5. 4 GENLDR Commands 

All commands must begin with the exclamation point (!) in column 1 of the input record and the command string 
beginning in column 2. All commands have the format: 

!CCC XXXX Comments 

Where CCC is the command name, of which only the first two characters are significant. XXXX is a hexadeci- 
mal value that must be separated from the command by at least one blank. Unless otherwise specified, where 
the term <^ex-value^ is used below, it represents a hexadecimal number in the range 0000 to FFFF. Leading 
zeros need not be specified, and only the last four significant digits are retained. If no value is specified, zero 
is used. Scanning of the operand is terminated by either the end of the line or encountering a character not in 
the hexadecimal set. Therefore, all commands may be commented if desired. 
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2. 5. 4. 1 ! OBS — Origin Base Sector 



The origin for the next base sector is set to <liex-value]^ . If this command is not specified, the next base 
sector is loaded immediately following the previous base sector (the initial base sector starts at X'lO if no !OBS 
command is given). This command should be used to prevent loading a base sector on top of an absolute sector. 

<5iex-value>must be in the range 0 ^ <liex-value> ^ X'FF or in the range X'FFOl ^<^ex-vaiue^ ^ X'FFFF. 
II the value is outside of these ranges, the base sector overflow message is given, the command is ignored, and 
GENLDR prompts for a new command from the Teletype. 



2. 5. 4. 2 ! OTS — Origin Top Sector 

The origin for the next top sector is set to <Jiex-value^ . If this command is not specified, the next top sector 
is loaded immediately following the previous top sector. This command should be used to prevent loading a top 
sector on top of an absolute sector. 

The highest value of <liex-value]> is a function of the memory available, and must not cause overlaying of the 
locations occupied by GENLDR. If this command is not given, the first top sector is loaded at location X'120. 

2. 5. 4. 3 ! RLM - Read Load Module 

This command may precede each LM to be loaded. The LM is loaded from the same device from which the 
!RLM command is entered. The !RLM command is not required if input is from the card reader, but it is 
necessary in the Teletype mode to start the reading of the paper tape. 

2. 5. 4. 4 ! CLR — Clear Memory and Restart GENLDR 

All computer memory outside of GENLDR is cleared to zeroes; then, GENLDR is reinitialized and started from 
its entry point. Since this command clears any previously loaded information, it should only be used as the 
first command to GENLDR or as a means of reinitialization following an error. 

2. 5. 4. 5 IRE - Restart GENLDR 

GENLDR is reinitialized and restarted at its entry point. This command does not clear memory, but is other- 
wise the same as the !CLR command, above. 



2. 5. 4. 6 ICR — Read Input from the Card Reader 
Subsequent input is accepted from the card reader. 



2. 5. 4. 7 ! TTY - Read Input from the Teletype 

Subsequent input is accepted from the Teletype. The card reader should be turned off before using the Teletype, 
since the IMP-16P card reader interface is also used by the high speed paper tape reader. Teletype input is 
accepted from either the paper tape or the keyboard, but only commands are echoed to the Teletype printer. 

2. 5.4.8 ! SY - Print the Symbol Table 

The symbol table is printed upon execution of this command. 
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2. f).4. 9 ! ER — Print Symbols in Error 

Multiply-defined and undefined symbols are printed when this command is read. 



2. 5,4. 10 IRA — Type Global Loaded Range 

The range of loaded addresses for each sector, plus the range of pointers generated (if any) and the current 
value of the entry point, is typed. This information is the same as printed on execution of a !G0 command. 
This command may be used to determine the status of the loaded program if an error occurs. 

2. 5.4. 11 !NLM — Inhibit Load Module Limit Printing 

This command inhibits the printing of the title record information, checksums, and address ranges that are 
printed for each load module. Printing may be restored by the ! LM command. 



2. 5.4. 12 ! LM — Enable Load Module Limit Printing 

This command enables the printing of the information for each load module that was inhibited by ! NLM. 
Printing of the information is the default state that is set upon initialization of GENLDR. 



2. 5. 4. 13 !GO — Execute the Loaded Program 

The entry Point specified in the last LM loaded can be overridden by specifying the entry point address 
(<Jiex-value];>). If <}iex-value^ is omitted, the last nonzero entry point specified is executed. If no nonzero 
entry point is specified and no value appears on the command, GENLDR prints an error message and prompts 
for a new command from the Teletype. Before transfer to the entry point, the global loaded program limits 
are printed on the Teletype. 



2. 5. 5 Messages 

The following messages may be output by GENLDR: 

GENERAL LOADER (REV. X) READY — GENLDR is initialized and ready to read commands. X is 
the current revision level of GENLDR, 

CMND? — The command is invalid or unrecognized. GENLDR prompts for a new command from the 
Teletype. 

CHAR — An LM card contains characters other than 0, 1, 2, 3, 4, 5, G, 7, 8, 9, A, B, C, D, E, 

and F. Since invalid punch codes are translated as '?•, this error can also occur on an invalid 
punch. Correct the card, reload it, and press RUN. 

CKSM — Checksum error on the last record read. K the checksum field is 0000, no checksum test 
is made. Processing of the record is completed after 'RUN' is pressed. The read may be 
retried: reload the record and then press RUN. 

BSOV — Base sector overflow. The run must be restarted, but the error may be corrected by proper 
use of the ! OBS and ! OTS commands. 

TSOV — Top sector overflow. The run must be restarted, but the error may be corrected by proper 
use of the ! OBS and ! OTS commands. This error is caused by exceeding the upper limit of 
memory, X'FFFF. 

AREA — Illegal attempt to load on top of the loader. Restart with valid ! OBS or ! OTS commands. 

<address]> MEM — Memory error at <address]> : probably an attempt to load into non-existent 
memory. 
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ENT? - No entry point specified for program. GENLDR transfers control to the Teletype for a new 
command. 

LENGTH — Record length error: the record is too long to fit in the buffer in GENLDR. The run may 
be restarted after the record is corrected. 

EXTN — Unable to locate external symbol in Symbol Table. This error may be caiised by attempting 
to load an LM with some missing symbol records or an erroneous patch which looks as if it is 
referencing an illegal external reference number. The run must be restarted. 

ADDR — Addressing error. This error occurs under the following conditions and the run must be 
restarted: 

1. Attempting to reference an indirect pointer generated by the assembler which, because of 
relocation, is forced to an address greater than X'7F. 

2. Using an index register in an instruction referencing a base sector variable allocated in a 
memory address in the range X'80 to X'FF. 

3. Attempting to use an index register in an instruction referencing an undefined external 
variable. 

4. Referencing an undefined external variable in an instruction which either is flagged 
indirect already or cannot be so flagged. 

SEQ — Record sequence error. The correct sequence is: (1) Title record, (2) Zero or more symbol 
records, (3) Zero or more data records, and (4) End record. Correct the record sequence, 
reload the LM, and restart the load. 

SYST — System error caused by a malfunction in system software or hardware. Recovery is not 
possible; GENLDR should be reloaded. 

SYMB — Symbol table overflow. Too many external symbols defined. The symbol table is allocated 
downward from the start of GENLDR; overflow will occur if an attempt is made to expand the 
symbol table into a region already loaded. 
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DQI 



National Semiconductor Corporation 

2900 Semiconductor Drive 
Santa Clara, California 95051 
(408) 732-5000 
TWX: 910-339-9240 



National Semiconductor GmbH 

D 808 Fuerstenfeldbruck 
tndustriestrasse 10 
West Germany 
Telephone: (08141) 1371 
Telex: 27649 



National Semiconductor Electronics SDNBHD 

Batu Berendam 
Free Trade Zone 
Malacca, Malaysia 
Telephone: 5171 

Telex: NSELECT 519 MALACCA (c/o Kuala Lumpur) 



National Semiconductor (UK) Ltd. 

Larkfield Industrial Estates 
Greenock, Scotland 
Telephone: (0475) 33251 
Telex: 778 632 



NS Electronics (PTE) Ltd. 
No. 1100 Lower Delta Rd. 
Singapore 3 
Telephone: 630011 
Telex: 21402 



REGIONAL AND DISTRICT SALES OFFICES 



ALABAMA 

DIXIE DISTRICT OFFICE 

3322 Memorial Parkway, S.W. #67 

Huntsville, Alabama 35802 

(206) 881-0622 

TWX: 810-726-2207 

ARIZONA 

*ROCKY MOUNTAIN REGIONAL OFFICE 
7349 Sixth Avenue 
Scottsdale, Arizona 85251 
(602) 945-8473 
TWX: 910-950-1195 

CALIFORNIA 

*NORTH-WEST REGIONAL OFFICE 
2680 Bayshore Frontage Road, Suite 112 
Mountain View, California 94043 
(415) 961-4740 
TWX: 910-379-6432 

NATIONAL SEMICONDUCTOR 
•DISTRICT SALES OFFICE 
Valley Freeway Center Building 
15300 Ventura Boulevard, Suite 305 
Sherman Oaks, California 91403 
(213) 783-8272 
TWX: 910-495-1773 

NATIONAL SEMICONDUCTOR 
SOUTH-WEST REGIONAL OFFICE 
17452 Irvine Boulevard, Suite M 
Tustin, California 92680 
(714) 832-8113 
TWX: 910-595-1523 

CONNECTICUT 

AREA OFFICE 
Commerce Park 
Danbury, Connecticut 06810 
(203) 744-2350 

•DISTRICT SALES OFFICE 
25 Sylvan Road South 
Westport, Connecticut 06880 
(203) 226-6833 



FLORIDA 

♦AREA SALES OFFICE 
2721 South Bayshore Drive, Suite 121 
Miami, Florida 33133 
(305) 446-8309 
TWX: 810-848-9725 

CARIBBEAN REGIONAL SALES OFFICE 
P.O. Box 6335 
Clearwater, Florida 33518 
(813)441-3504 

ILLINOIS 

NATIONAL SEMICONDUCTOR 
WEST-CENTRAL REGIONAL OFFICE 
800 E. Northwest Highway, Suite 203 
Mt. Prospect, Illinois 60056 
(312) 394-8040 
TWX: 910-689-3346 

INDIANA 

NATIONAL SEMICONDUCTOR 
NORTH-CENTRAL REGIONAL OFFICE 
P.O. Box 40073 
Indianapolis, Indiana 46240 
(317) 255-5822 

KANSAS 

DISTRICT SALES OFFICE 
13201 West 82nd Street 
Lenexa, Kansas 66215 
(816) 358-8102 

MARYLAND 

CAPITAL REGIONAL SALES OFFICE 
300 Hospital Drive, No. 232 
Glen Burnie, Maryland 21061 
(301) 760-5220 
TWX: 710-861-0519 

MASSACHUSETTS 

*NORTH-EAiST REGIONAL OFFICE 
No. 3 New England, Exec. Office Park 
Burlington, Massachusetts 01803 
(617) 273-1350 
TWX: 710-332-0166 



MICHIGAN 

•DISTRICT SALES OFFICE 
23629 Liberty Street 
Farmington, Michigan 48024 
(313) 477-0400 

MINNESOTA 

DISTRICT SALES OFFICE 

8053 Bloomington Freeway, Suite 101 

Minneapolis, Minnesota 55420 

(61 2) 888-3060 

Telex: 290766 

NEW JERSEY/NEW YORK CITY 

MID-ATLANTIC REGIONAL OFFICE 

301 Sylvan Avenue 

Englewood Cliffs, New Jersey 07632 

(201) 871-4410 

TWX: 710-991-9734 

NEW YORK (UP3TATE) 

CAN-AM REGIONAL SALES OFFICE 
104 Pickard Drive 
Syracuse, New York 13211 
(315) 455-5858 

OHIO/PENNSYLVANIA/ 
W. VIRGINIA/KENTUCKY 

EAST-CENTRAL REGIONAL OFFICE 
Financial South Building 
5335 Far Hills, Suite 214 
Dayton, Ohio 45429 
(513) 434-0097 

TEXAS 

•SOUTH-CENTRAL REGIONAL OFFICE 
5925 Forest Lane, Suite 205 
Dallas, Texas 75230 
(214) 233-6801 
TWX: 910-860-5091 

WASHINGTON 

DISTRICT OFFICE 
300 1 20th Avenue N.E. 
Building 2, Suite 205 
Bellevue, Washington 98005 
(206) 454-4600 



INTERNATIONAL SALES OFFICES 

AUSTRALIA 

NS ELECTRONICS PTY, LTD. 

Cnr. Stud Road & Mountain Highway 
Bayswater, Victoria 3153 
Australia 

Telephone: 729-6333 
Telex: 32096 

CANADA 

•NATIONAL SEMICONDUCTOR CORP, 
1111 Finch Avenue West 
Downsview, Ontario, Canada 
(416) 635-9880 
TWX: 610-492-1334 

DENMARK 

NATIONAL SEMICONDUCTOR 
SCANDINAVIA 
Vordingborggade 22 
2100 Copenhagen 
Denmark , 
Telephone: (01) 92-OBRO-5610 
Telex: DK 6827 MAGNA 



ENGLAND 

NATIONAL SEMICONDUCTOR (UK) LTD. 
The Precinct 

Broxbourne, Hertfordshire 
England 

Telephone: Hoddesdon 69571 
Tetex: 267-204 

FRANCE . 

NATIONAL SEMICONDUCTOR 
FRANCE S.A.R.L. 
28, Rue de la Redoute 
92260-Fontenay-Aux-Roses 
Telephone: 660-81-40 
TWX: NSF25956F 

HONG KONG 

♦NATIONAL SEMICONDUCTOR 
HONG KONG LTD. 
9 Lai Yip Street 
Kwun Tung, Kowloon 
Hong Kong 
Telephone: 3-458888 
Telex: HX3866 



JAPAN 

•NATIONAL SEMICONDUCTOR JAPAN 
Nakazawa Building 
1-19 Yotsuya, Shinjuku-Ku 
Tokyo, Japan 160 
Telephone: 03-359-4571 
Telex: J 28592 

SWEDEN 

NATIONAL SEMICONDUCTOR SWEDEN 

Sikvagen 17 

13500 Tyreso 

Stockholm 

Sweden 

Telephone: (08) 712-04-80 

WEST GERMANY 

♦NATIONAL SEMICONDUCTOR GMBH 
8000 Munchen 81 
Cosimstrasse 4 
Telephone: (0811) 915-027 



'Microprocessor System Specialist Available 
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